Table des matières
4 billet(s) pour janvier 2026
| AWX sur K8S Kind - partage de fichier pour les blob - Execution pods | 2026/01/26 10:15 | Jean-Baptiste |
| Notes rsh rcp | 2026/01/21 18:08 | Jean-Baptiste |
| Git - Duplication d'un dépôt | 2026/01/19 10:22 | Jean-Baptiste |
| Exemple simple de conf Nagios | 2026/01/14 10:07 | Jean-Baptiste |
Notes Perl
Voir aussi : Raku
Voir :
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)
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;
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
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 :
- source = D'où proviennent les données à copier;
- cible = où seront copiées les données traitées par la commande;
- bs = taille des blocs, de puissance 2, par défaut égale à 512 octets;
- skip = Ignorer le nombre indiqué de blocs (dont la taille est fournie par ibs) au début de la lecture;
- seek = Ignorer le nombre indiqué de blocs (dont la taille est fournie par ibs) au début de l'écriture.
- 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
