Outils pour utilisateurs

Outils du site


blog

Notes permissions Unix POSIX

Voir :

$ stat -c "%a %A" ~/test/
1770 drwxrwx--T
$ stat -c "%a %U:%G %n" /usr/bin/passwd
4701 root:root /usr/bin/passwd

FIXME

2025/03/24 15:06

Notes Perl

Variables PATH

PERL5LIB

$ env -i perl -V
...
@INC:
 /usr/lib/perl5/site_perl/5.18.0/x86_64-linux-thread-multi-ld
 /usr/lib/perl5/site_perl/5.18.0
 /usr/lib/perl5/5.18.0/x86_64-linux-thread-multi-ld
 /usr/lib/perl5/5.18.0
 .
PATH="/home/jean/perl5/bin${PATH:+:${PATH}}"; export PATH;
PERL5LIB="/home/jean/perl5/lib/perl5${PERL5LIB:+:${PERL5LIB}}"; export PERL5LIB;
PERL_LOCAL_LIB_ROOT="/home/jean/perl5${PERL_LOCAL_LIB_ROOT:+:${PERL_LOCAL_LIB_ROOT}}"; export PERL_LOCAL_LIB_ROOT;
PERL_MB_OPT="--install_base \"/home/jean/perl5\""; export PERL_MB_OPT;
PERL_MM_OPT="INSTALL_BASE=/home/jean/perl5"; export PERL_MM_OPT;

CPAN

Installer un module

cpan JSON

Installer un module téléchargé localement

tar xzvf JSON-4.10.tar.gz
cd JSON-4.10/
perl Makefile.PL PREFIX=~
make test
make install

code-style-guidelines (exemple)

Source : https://github.com/centreon/centreon-plugins/blob/develop/doc/en/developer/plugins_global.md#5-code-style-guidelines

Code Style Guidelines Introduction

Perl code from Pull-request must conform to the following style guidelines. If you find any code which doesn't conform, please fix it.

1 Indentation

Space should be used to indent all code blocks. Tabs should never be used to indent code blocks. Mixing tabs and spaces results in misaligned code blocks for other developers who prefer different indentation settings. Please use 4 for indentation space width.

    if ($1 > 1) {
    ....return 1;
    } else {
        if ($i == -1) {
        ....return 0;
        }
        return -1
    }
2 Comments

There should always be at least 1 space between the # character and the beginning of the comment. This makes it a little easier to read multi-line comments:

    # Good comment
    #Wrong comment
3 Subroutine & Variable Names

Whenever possible, use underscore to seperate words and don't use uppercase characters:

    sub get_logs {}
    my $start_time;

Keys of hash table should use alphanumeric and underscore characters only (and no quote!):

    $dogs->{meapolitan_mastiff} = 10;
4 Curly Brackets, Parenthesis

There should be a space between every control/loop keyword and the opening parenthesis:

    if ($i == 1) {
        ...
    }
    while ($i == 2) {
        ...
    }
5 If/Else Statements

'else', 'elsif' should be on the same line after the previous closing curly brace:

    if ($i == 1) {
        ...
    } else {
        ...
    }

You can use single line if conditional:

    next if ($i == 1);
Suite

libraries Strict and warnings are mandatory

use strict;
use warnings;

Autres

use feature bitwise;

https://perldoc.pl/feature

2025/03/24 15:06

Notes partitionnement

Voir Partitionnement - Aide mémoire : parted, fdisk, sfdisk, gdisk, sgdisk

parted

parted --script -a optimal /dev/device mklabel gpt mkpart primary 0% 100%
parted --script -a optimal /dev/device rm 1
luns=`ls|grep -v control`
for i in $luns
do
  parted -a optimal -s --  /dev/mapper/$i mklabel gpt mkpart primary xfs 0% 100%
done

https://pure-storage-openstack-docs.readthedocs.io/en/wallaby/swift/section_swift-partitioning.html

You can verify that the partition was successfully created and is properly aligned by using the parted command:

# parted /dev/mapper/3624a937043be47c12334399b00016d73 align-check optimal 1
1 aligned

sgdisk (compatible GPT)

Backup the table of /dev/sda:

sgdisk --backup=table /dev/sda

Restore the table to the new disk:

sgdisk --load-backup=table /dev/sdb

Backup and Restore from /dev/sda to /dev/sdb in one command:

sgdisk -R /dev/sdb /dev/sda

Finally randomize the GUID of all partitions on the disk:

sgdisk -G /dev/sdb

Method for MBR-Tables Copy table from /dev/sda to /dev/sdb:

sfdisk -d /dev/sda | sfdisk /dev/sdb

(Optional)If you don’t see the partitions, read it again:

sfdisk -R /dev/sdb
2025/03/24 15:06

La commande dd

Introduction

Extrait de la page de man de dd :

“dd copie un fichier (par défaut, depuis l'entrée standard vers la sortie standard) en permettant de sélectionner la taille de bloc, et d'effectuer des conversions.”

Utilisée fréquemment, la commande dd est très simple d'utilisation, très puissante et… tout aussi dangereuse. Vérifiez toujours bien les commandes deux (trois ?) fois avant de les lancer.

LES COMMANDES QUI SUIVENT PEUVENT VOUS FAIRE PERDRE TOUTES LES INFORMATIONS CONTENUES DANS VOTRE MACHINE SI ELLES NE SONT PAS CONVENABLEMENT UTILISÉES. VOUS ÊTES PRÉVENUS!

NOTE: Pour pouvoir être copiée, déplacée, agrandie ou réduite, la partition source doit au préalable être “démountée” du système (voir “umount”).

Syntaxe

La syntaxe d'une ligne de commandes utilisant dd se présente généralement sous cette forme:

dd if=<source> of=<cible> bs=<taille des blocs> skip= seek= conv=<conversion>

Arguments :

  1. source = D'où proviennent les données à copier;
  2. cible = où seront copiées les données traitées par la commande;
  3. bs = taille des blocs, de puissance 2, par défaut égale à 512 octets;
  4. skip = Ignorer le nombre indiqué de blocs (dont la taille est fournie par ibs) au début de la lecture;
  5. seek = Ignorer le nombre indiqué de blocs (dont la taille est fournie par ibs) au début de l'écriture.
  6. conv = Modifier le fichier comme indiqué par l'argument conversion, qui peut prendre les valeurs suivantes (pas d'espace autour des virgules lorsque plusieurs arguments sont fournis) :
ascii, ebcdic, ibm, block, unblock, lcase, ucase, swab, noerror, notrunc, sync.
Utilisation

Copier une partition d'un disque dur vers un partition d'un autre disque dur

Copie l'intégralité de la partition sda9 vers la partition sdb1 et ne pas interrompre la copie en cas d'erreurs.

dd if=/dev/sda9 of=/dev/sdb1 bs=4096 conv=noerror

noerror : Continuer même en cas d'erreur.

Remarque au sujet de l'UUID.

Copier une partition autre vers une partition copie aussi l'UUID puisqu'il est inscrit dans la partition même.\ Vous vous retrouveriez alors avec deux partitions qui ont le même UUID…

# blkid
...
/dev/sda9: UUID="a5355774-2e6b-45fe-8993-0f23602c1616" TYPE="ext2"
/dev/sdb1: UUID="a5355774-2e6b-45fe-8993-0f23602c1616" TYPE="ext2"

Il faut alors modifier l'UUID de la partition copiée pour ne pas avoir de conflit si la partition originale et sa copie sont accessibles au système :

# tune2fs -U random /dev/sdb1
# blkid
/dev/sda9: UUID="a5355774-2e6b-45fe-8993-0f23602c1616" TYPE="ext2"
/dev/sdb1: UUID="75aa7a37-d2a2-4cf4-88f8-616067c7a684" TYPE="ext2"
Cloner un disque dur en entier

Copie de l'intégralité (y compris le mbr) du disque sdg vers le disque sdh:

dd if=/dev/sdg of=/dev/sdh conv=noerror
Réaliser un fichier image ISO copie d'un CD-ROM
dd if=/dev/sr0 of=/home/laurent/cd.iso bs=2048

Pour monter le fichier image ISO obtenu :

mkdir /mnt/cd
mount -o loop -t iso9660 cd.iso /mnt/cd

Montage permanent par /etc/fstab :

/chemin_vers_iso/cd.iso   /mnt/cd  iso9660 rw,user,noauto 0 0
Effacer un lecteur

ATTENTION, COMMANDE DANGEREUSE!

Pour les paranos… La commande suivante remplie 7 fois de suite un périphérique avec des données aléatoires. Autant dire qu'il ne sera plus possible de récupérer quoi que ce soit sur ce périphérique…

for n in $(seq 7);
do 
  dd if=/dev/urandom of=/dev/sdc bs=8b;
done
Sauvegarder le chargeur de boot d'un disque dur
dd if=/dev/sda of=ChrgBoot.dd bs=440 count=1

Cette commande copiera les 440 premiers octets du disque dur dans un fichier.

Sauvegarder le MBR d'un disque dur
dd if=/dev/sda of=MBR.dd bs=512 count=1

Cette commande copiera les 512 premiers octets du disque dur dans un fichier.

Sauvegarder la table des partitions d'un disque dur
dd if=/dev/sda of=TablePart.dd bs=64 count=1 skip=446

Cette commande copiera les 512 premiers octets du disque dur dans un fichier.

pour restaurer la table de partition

dd if=TablePart.dd of=/dev/sda bs=64 count=1 seek=446

Cette commande copiera la table des partitions contenue dans le fichier TablePart.dd sur le disque /dev/sda

Sauvegarder un disque dur ou une partition dans une image compressée

La ligne de commandes suivante permet de créer un fichier compressé, qui pourra être utilisé pour restaurer la partition “n” (“n” est une valeur numérique) du disque “/dev/sdX” (“X” est une lettre alphabétique). (peu importe le type de partition)

#dd if=/dev/sdXn | gzip -c > /media/suportamovible/fichierimage_part_dd.gz
dd if=/dev/sdXn | pigz -c > /media/suportamovible/fichierimage_part_dd.gz
 
# Avec taux de compression adapté automatiquement
sudo dd if=/dev/sda | pv | zstd --adapt > image.dd.zst
zstdcat image.dd.zst | pv | sudo dd of=/dev/sda )

Dans cette ligne de commandes, le programme “dd” lit par blocs (de 512 octets par défaut) le contenu de la partition “n” du disque “X” (/dev/sdXn). Le flux de sortie du programme “dd” est connecté par un tube anonyme (|) au flux d'entrée du programme “gzip”. “gzip” va compresser ce flux et le retourner par son flux de sortie (option “c”) qui sera re-dirigé par “>” vers le fichier “/media/suportamovible/fichierimage_part_dd.gz”. Si le fichier “/media/suportamovible/fichierimage_part_dd.gz” existait avant l'exécution de cette ligne de commandes, il serait “écrasé”.

Pour restaurer la partition ainsi sauvegardée faire :

#gzip -cd /media/suportamovible/fichierimage_part_dd.gz | dd of=/dev/sdXn
pigz -cd /media/suportamovible/fichierimage_part_dd.gz | dd of=/dev/sdXn

Dans cette commande, le programme “gzip” dé-compresse (option “d”) le fichier “/media/suportamovible/fichierimage_part_dd.gz”. Le flux de sortie du programme “gzip” (option “c”) est connecté à un tube anonyme (|) qui est connecté à l'entrée du programme “dd”. La sortie (of=) du programme “dd” se fera sur la partition “n” du disque “X” (/dev/sdXn), et le contenu de cette partition sera écrasé et remplacé par le contenu du fichier sauvegardé par la ligne de commandes précédente.

Autres

zip -r - . | dd of=/dev/nrst0 obs=16k

Autres commandes

Clean up partition table and MBR
sgdisk --zap-all -- /dev/sdX
2025/03/24 15:06
blog.txt · Dernière modification : de 127.0.0.1

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki