Linux
find
find . -type d -name "xxx"
find . -type f -exec chmod -x {} \;
Pour traiter les répertoires : -type d
Chaînage
find . -maxdepth 1 -type d -newermt 2018-01-03 | cut -d'/' -f 6 | grep 2017
find . -maxdepth 1 -type d | grep -Ev "/[0-9]{4}$" | xargs rmdir
-Ev : Expression régulière étendue + résultat inversé
Additionner la taille des fichiers recherchés
find /path/to/files/ -name *.log* | xargs du -hs --total | tail -1
sed
sed -i 's/regex/string/g' file
Chaînage
cat infile | sed 's/regex1/string/' | sed -r 's/re\(g\)ex2/\str\1ing/' > outfile
-E, -r, –regexp-extended
rsync
Script de sauvegarde
#!/bin/bash
# A script to perform incremental backups using rsync
set -o errexit
set -o nounset
set -o pipefail
readonly SOURCE_DIR="${HOME}"
readonly BACKUP_DIR="/mnt/data/backups"
readonly DATETIME="$(date '+%Y-%m-%d_%H:%M:%S')"
readonly BACKUP_PATH="${BACKUP_DIR}/${DATETIME}"
readonly LATEST_LINK="${BACKUP_DIR}/latest"
mkdir -p "${BACKUP_DIR}"
rsync -av --delete \
"${SOURCE_DIR}/" \
--link-dest "${LATEST_LINK}" \
--exclude=".cache" \
"${BACKUP_PATH}"
rm -rf "${LATEST_LINK}"
ln -s "${BACKUP_PATH}" "${LATEST_LINK}"
# crontab -e
# 0 */12 * * * /path/to/backup-script.sh
Encodage des caractères
Voir l'encodage d'un fichier
file -i file.txt
ou
uchardet file.txt
Ajouter le BOM à un fichier UTF-8
sed -i '1s/^\(\xef\xbb\xbf\)\?/\xef\xbb\xbf/' file.txt
Logging
Logger la sortie d'une commande tout en l'affichant dans la console
echo "gromf!" 2>&1 | tee log.out
Compter le nombre de lignes par seconde ajoutées à un fichier de log
tail -f /var/log/haproxy.log | pv --line-mode --rate > /dev/null
Gestion des disques et de l'espace disque
Agrandissement d'une partition suite au redimensionnement d'un disque
A adapter selon le disque à redimensionner.
Initier un scan des nouvelles caractéristiques du disque :
echo 1 > /sys/class/block/sda/device/rescan
Vérifier la prise en compte de la demande de scan :
dmesg [9937790.353627] sd 0:0:2:0: [sda] 419430400 512-byte logical blocks: (215 GB/200 GiB) [9937790.353767] sda: detected capacity change from 209715200 to 419430400
Si nécessaire, installer growpart.
Sous Debian :
apt install cloud-utils
Agrandir la partition :
growpart /dev/sda 1
Agrandir le système de fichier :
resize2fs /dev/sda1
Pour automatiser le processus, il est possible de planifier l'exécution d'un script.
Attention, le script n'a pas été testé !
Source : https://codenotary.com/blog/enlarge-a-disk-and-partition-of-any-linux-vm-without-a-reboot
Par exemple, créer la tâche planifiée suivante dans /etc/cron.d/resize_disk :
*/5 * * * * root /usr/local/bin/disk_resize.sh
Contenu de disk_resize.sh :
#!/bin/bash
LOGFILE=/data/log/speed/resize.log
LOCKFILE=/tmp/enlarge.lock
export PATH=/usr/sbin:/usr/bin:/sbin:/bin
dotlockfile -r 0 $LOCKFILE || exit 1
echo 1 > /sys/class/block/sda/device/rescan
sleep 5
GROWPART_OUT=`growpart /dev/sda 2`
if [ $? -eq 0 ]; then
echo `date` >> $LOGFILE
echo "trying to resize fs" >> $LOGFILE
echo $GROWPART_OUT >> $LOGFILE
resize2fs /dev/sda2 >> $LOGFILE 2>&1
echo `date` >> $LOGFILE
echo "resize done" >> $LOGFILE
fi
echo 1 2>/dev/null >/sys/class/block/sdb/device/rescan
sleep 5
GROWPART_OUT=`growpart /dev/sdb 1`
if [ $? -eq 0 ]; then
echo `date` >> $LOGFILE
echo "trying to resize fs" >> $LOGFILE
echo $GROWPART_OUT >> $LOGFILE
resize2fs /dev/sdb1 >> $LOGFILE 2>&1
echo `date` >> $LOGFILE
echo "resize done" >> $LOGFILE
fi
dotlockfile -u $LOCKFILE
Contrôler la taille des fichiers du système
duc index -x --exclude=/dev --exclude=/proc --exclude=/sys --exclude=/net --exclude=/run -v --debug /
Monitorer la taille d'un fichier en temps réel
watch -n 1 "ls -lh /root/.cache/duc | awk '{print \$5}'"
Gestion des utilisateurs
Ajouter un utilisateur à un groupe
usermod -aG <GROUP> <USER>
Désactiver un compte utilisateur
usermod -L -e 1 <USER>
-e 1 : Date d'expiration au 02/01/1970 → Désactivation définitive
Gestion des processus
Tuer à l'aide de la commande ps
kill $(ps aux |grep -i illustrator | awk '{print $2}')
Interactivité
Enregistrer une saisie
read -p "Veuillez saisir du texte" VAR
Enregistrer une saisie de mot de passe
read -s -p "Mot de passe :" PASSWD
Gestion de l'énergie
Eteindre la machine
shutdown -h now
OU
init 0
Niveaux d'exécution
- 0 — Arrêt.
- 1 — Mode texte mono-utilisateur.
- 2 — Pas utilisé
- 3 — Mode texte multi-utilisateurs complet.
- 4 — Pas utilisé
- 5 — Mode graphique multi-utilisateurs complet (avec un écran de connexion de type X Window)
- 6 — Redémarrage.
Gestion du réseau
Renouveler le bail DHCP
Libération du bail
sudo dhclient -r
Obtention d'un nouveau bail
sudo dhclient
Désactiver IPv6
Méthode Grub
/etc/default/grub
GRUB_CMDLINE_LINUX_DEFAULT="ipv6.disable=1"
update-grub
/etc/netconfig
#udp6 tpi_clts v inet6 udp - - #tcp6 tpi_cots_ord v inet6 tcp - -
Methode systemctcl
sudo vim /etc/sysctl.d/60-custom.conf
net.ipv6.conf.all.disable_ipv6 = 1 net.ipv6.conf.default.disable_ipv6 = 1 net.ipv6.conf.lo.disable_ipv6 = 1
sudo sysctl -p sudo systemctl restart procps
cat /proc/sys/net/ipv6/conf/all/disable_ipv6 1
Gestion de la localisation
Configuration du clavier
dpkg-reconfigure keyboard-configuration
Réparation des problèmes de langues
perl: warning: Please check that your locale settings:
LANGUAGE = (unset),
LC_ALL = (unset),
LC_TIME = "fr_FR.UTF-8",
LC_MONETARY = "fr_FR.UTF-8",
LC_ADDRESS = "fr_FR.UTF-8",
LC_TELEPHONE = "fr_FR.UTF-8",
LC_NAME = "fr_FR.UTF-8",
LC_MEASUREMENT = "fr_FR.UTF-8",
LC_IDENTIFICATION = "fr_FR.UTF-8",
LC_NUMERIC = "fr_FR.UTF-8",
LC_PAPER = "fr_FR.UTF-8",
LANG = "en_GB.UTF-8"
are supported and installed on your system.
sudo locale-gen fr_FR.UTF-8 sudo dpkg-reconfigure locales
Sécurité
sudo
Ajouter un utilisateur au sudoers
La commande consiste simplement à ajouter l'utilisateur au groupe sudo.
usermod -aG sudo <USER>
Augmenter le délai de saisie du mot de passe
sudo visudo
Defaults timestamp_timeout=3600
-1 : illimité
Pour un utilisateur en particulier :
Defaults:username timestamp_timeout=3600
Masquer les astérisques lors de la saisie du mot de passe
echo 'Defaults !pwfeedback'|sudo tee /etc/sudoers.d/0pwfeedback
Le nom du fichier 0pwfeedback peut être à adapter selon les configurations.
Divers
Exécuter en tant que
Utilisateur standards
su - <USER> -c "<COMMAND>"
Spécifier le groupe et le shell
su -g <GROUP> <USER> -s /bin/bash -c "<COMMAND>"
Exécuter une commande n fois
for i in {1..n}; do command; done;
Exécuter une commande à intervalles réguliers
watch -n 1 date
Supprimer les noyaux inutilisés
echo $(dpkg --list | grep linux-image | awk '{ print $2 }' | sort -V | sed -n '/'`uname -r`'/q;p') $(dpkg --list | grep linux-headers | awk '{ print $2 }' | sort -V | sed -n '/'"$(uname -r | sed "s/\([0-9.-]*\)-\([^0-9]\+\)/\1/")"'/q;p') | xargs sudo apt-get -y purge
sudo apt autoremove --purge
Déporter l'affichage en tant que root
sudo xauth add $(xauth -f ~befe/.Xauthority list|tail -1)
Créer un répertoire et se rendre à l'intérieur dans la foulée
mcd() { mkdir "$@" 2> >(sed s/mkdir/mcd/ 1>&2) && cd "$_"; }
Vérifier les mises à jour du BIOS (et autres firmwares)
fwupdmgr get-upgrades