(modifié le 20 novembre 2014 à 10:42)

linuxCertaines commandes Linux sont très pratiques, voir indispensables. Parce qu'il est impossible de retenir toutes les commandes, je vous propose à travers ce billet celles que j'utilise le plus souvent, ou qui sont tout simplement intéressantes et peu courantes. Voici mon mémo ou memento personnel, en libre accès. Ce billet est régulièrement mis à jour, n'hésitez pas à revenir, les dernières commandes ajoutées sont en haut.

Lister les cron (crontab) pour tous les utilisateurs

Adresse IP

Toutes distributions : configuration minimaliste.

QoS

Quelques mods connus pour servir HTTP : mod_bw, mod_cband, moq_qos

Sous Debian avec traffic control (tc) inclut dans le paquet iproute (qdisc, etc)

Rsnapshot

Guide

Bien utiliser la commande cd

Pour revenir au répertoire précédent :

+d'infos

Gestion des ACL (accesslist)

L'echainement des commandes ("&&" ou "||" ou ";")

rsync (classique et via ssh)

Copie entre deux serveurs :

rsync -avz chemin_local/ root@remote:/chemin_distant/

Distant vers local :

rsync -avzh root@remote:/chemin/distant /chemin/local

Tutoriel

Dnsmasq

Configuration de base (particularité "--domain-needed")

Masque la signature Apache/PHP (powered by...)

Procédure

Activer SMART avec smartctl

smartctl --smart=on --offlineauto=on --saveauto=on /dev/sdX

Pour utiliser gsmartcontrol avec un disque USB qui ne remonte pas la table SMART :

Correspond à :

The format of the device is "<device>::<type>::<extra_args>", where type and extra_args are optional. This option is useful with --no-scan to list certain drives only. You can specify this option multiple times. Example: --add-device /dev/sda --add-device /dev/twa0::3ware,2 --add-device '/dev/sdb::::-T permissive'

Réglage d'heure décalée

Debian/Ubuntu (tz pour TimeZone) :

Vérifier ensuite le fichier /etc/timezone

En cas de pépin modifier le fichier (UTC=no) :

Vider le contenu d'un fichier existant

ou :

Lire des fichiers volumineux

How-to

php.ini

Recommandations des fonctions PHP à désactiver

Générer facilement un .htaccess

Tutoriel

Expressions régulières (regex)

PHP (adaptable)

Connaitre les dépendances d'un .deb

Utiliser gdebi pour en résoudre un maximum :

Apt-get vs Aptitude

Automatiser le mises à jour

Installer une version spécifique d'un paquet (package)

Lister les services qui tournent

Pour vérifier qu'un service est en écoute :

-u = udp Envoyer du contenu dans un serveur rsyslog echo "blogmotion" | ncat -u SERVERNAME 514

iotop, screen, dtach, multitail...

De nombreux outils comme le multitail sont peu connus et pourtant très pratiques : liste des outils.

Effectuer un reboot d'urgence à distance

Avant de prendre la voiture et d'aller au DC, procédure d'urgence à tenter pour le reboot :

Source

Plus de réseau après changement matériel

Linux (Debian) stocke la relation entre adresse MAC et l’interface (eth0, eth1, etc), si changement hardware et donc d’adresse MAC, le système ne trouve plus l’adresse MAC associée à eth0. La nouvelle adresse MAC du système est alors associée à eth1, ce qui pose problème. Il faut donc reconfigurer le système en exécutant la commande suivante afin de supprimer le fichier contenant les correspondances MAC-ethX (ce fichier sera automatiquement recréé au prochain redémarrage) :

Envoyer un mail en ligne de commande (sendmail)

cat fichier | sendmail -f expediteur@domain.com destinataire@domaine.com

Recherche une occurrence

r : récursif dans les répertoires i : non sensible à la casse

/etc/sources.list

Correspondance des sources : deb : Adresse de paquets binaires (compilés) deb-src : Adresse de paquets sources main : Les paquets principaux contrib : Les paquets plus vraiment supportés non-free : Les paquets de logiciels non libres (propriétaires) source

Synology

Astuces et tutoriels de config Commandes CLI (ligne de commande) Gérer la base de données d'indexation Vérifier table SMART d'un disque  (sdx = lettre du disque: sda, sdb, ...)

Récupérer des données d'un RAID

Lien 1 - Lien 2

Editer des partitions pas dans l'ordre dans la table

Tutoriel

Paginer un résultat MySQL en ligne de commande

Paginer avec MySQL cli

Redémarrer inetd (restart inetd)

Sur Debian :

Pour le killer violemment (toutes distributions) :

UserMod

Serveur FTP chrooté avec ProFTPD

http://alethotech.com/?p=309

Serveur SFTP chrooté avec rssh

sur Debian Etch / Lenny

Manipuler les partitions

Trois commandes fondamentales:

Lister les UUID des partitions :

En affichant en plus le type de partition (système de fichier) :

Voir l'espace disque restant :

Ajout d'une nouvelle partition ou d'un nouveau disque avec point de montage fstab (doc debian)

Problèmes de Grub

Réinstaller Grub :

ou plus complet : http://ubuntuforums.org/showthread.php?t=1581099 il y a une différence importante entre Grub et Grub2 dans la numérotation des partitions (source):

  • Sur Grub, la numérotation démarre à 0 pour les disques physiques ET pour les partitions. Exemple : /dev/hda1 ou /dev/sda1 sera nommé hd(0,0) par grub.
  • Sur Grub2, elle démarre à 0 pour les disques physiques et à 1 pour le numéro de la partition. Exemple : /dev/hda1 ou /dev/sda1 sera nommé hd(0,1) par grub-pc.

Précaution pour éviter un panic à distance lors de le compilation à distance de GRUB.

Chrooter un environnement

  • sudo fdisk -l (pour déterminer le nom du disque depuis le LiveCD Ubuntu, exemple “/dev/sdxy″ - avec x le disque dur et y la partition.). Personnellement je préfère la commande blkid
  • sudo mount /dev/sdxy /mnt
  • sudo mount --bind /dev /mnt/dev
  • sudo mount --bind /proc /mnt/proc
  • sudo mount --bind /sys /mnt/sys
  • sudo chroot /mnt
  • apt-get install grub-pc (facultatif, seulement si vous êtes sous Ubuntu/Debian et souhaitez réinstaller)
  • grub-mkconfig -o /boot/grub/grub.cfg (assurez-vous qu'aucun message d'erreur ne soit renvoyé)
  • grub-install /dev/sdx (essayer grub-install --recheck /dev/sdxy si cela ne fonctionne pas)
  • Ctrl+D (pour quitter le chroot)
  • sudo umount /mnt/dev
  • sudo umount /mnt

Compiler un noyau Debian

Comparer le contenu de deux répertoires (non récursif)

Récupérer la sortie d'une commande dans une variable

[shell]var=$(command-name-here)<br />var=$(command-name-here arg1)<br />var=$(/path/to/command)<br />var=$(/path/to/command arg1 arg2)[/shell]

Ou :

[shell]var=command-name-here<br />var=command-name-here arg1<br />var=/path/to/command<br />var=/path/to/command arg1 arg2[/shell]

source

Récupérer la date et l'heure dans une variable

source

Vérifier si un fichier existe en une seule ligne

Changer de shell

Lister les shells :

Copier rapidement un fichier/dossier

Garder sa Debian à jour

Montage et démontage CIFS

Monter une ressource (partage windows) depuis Linux:

Démonter le partage :

Je vous conseille d'utiliser plutôt autofs que de tout faire à la main !

Liste des processus utilisant un port

Pour lister les ports en écoute "LISTEN" et savoir quel processus monopolise un port précis avec lsof :

(linux et bsd) Plus d'infos Ou :

Comprendre et débuter avec IPTables

Tutoriel

Raccourcis clavier pour bash

Liste ici

Forcer la vitesse d'une carte réseau

Avec ethtool :

Avec mii-tool :

Entrées et sorties d'un script

Voir cette documentation

Connaître la version d'une distribution

(sous debian)

(sous redhat)

(sous fedora)

(sous certaines distributions)

update-rc.d (debian like)

Sur les distributions debian like il faut utiliser update-rc.d, avec différente niveaux

Ajouter le lancement d'un service au démarrage :

Supprimer un service du démarrage :

+d'infos

chkconfig et les run level

Attention : inittab a été remplacé par Upstart sous Ubuntu RedHat Like (CentOS, Mandriva, etc.)

Plus d'infos : lien 1, lien 2 Pour lister les run level d'un service :

(Pensez à installer chkconfig via apt/yum si non installé) Pour définir les run level d'un service :

notice : remplacer "23456" par les run level souhaités

Tunnel SSH avec translation de port local (local forwarding)

(xx = port ssh, à préciser si différent de 22) Exemple :

[shell]ssh -L 9089:localhost:3389 xhark@109.238.2.200 -p443[/shell]

Cela aura pour effet de rediriger toutes les requêtes arrivant sur le port 9089 de votre machine local vers le port 3389 de la machine distante. Dans cet exemple, il s'agit d'une connexion sur un serveur Windows ayant OpenSSH écoutant sur le port 443. Le but est de réaliser un tunnel SSH pour prendre le contrôle en bureau à distance (RDP) sur le port par défaut 3389.

Tunnel SSH avec translation de port dynamique (dynamic forwarding)

Dans cet exemple nous ouvrons un tunnel dynamique qui permettra de surfer à travers le tunnel SSH via un proxy de type Socks.

Afficher l'historique des connexions SSH

[shell]last | more[/shell]

Terminer une session shell (logout en terminal)

combinaison des touches : ctrl+D

Archive .gz

Liste les fichiers contenus dans l'archive :

[shell]gunzip -l archive.gz[/shell]

Extraire (dans le dossier courant)

[shell]gunzip -d archive.gz[/shell]

Archive .tar

Extraire (dans le dossier courant) :

[shell]tar xvf archive.tar[/shell]

Archive .tar.gz

>>> Compresser <<< :

z : compresser en utilisant gzip
c : creation
v : bavard (liste les fichiers à l'écran) f : fichier

<<< Extraire >>> :

Extraire vers un dossier :

A lire également et CCM

Décompresser un BZ2 :

Compresser en ZIP

r : récursif

Décompresser une archive ZIP

Droits (chmod)

Plus d'infos sur le chmod chez Linux-France Pour tout ce qui concerne SUID, GUID et le Sticky Bit voir ici.

Arbre des processus

Résume les commandes linux importantes :

Documentation rapide sur une commande :

Rechercher un fichier avec locate

Pour mettre à jour votre base de recherche :

Rechercher un fichier avec find

Exemple :

Localiser une commande

Lister tous fichiers du répertoire courant

Afficher le répertoire courant

Lister seulement les adresses IP des interfaces réseau

Lister les processus

Réaliser et compresser un dump mysql (GZ)

Plus d'infos ici

Accéder à un partage Windows / Samba

mkdir /mnt/windows mount -t cifs //adresseip/monpartage /mnt/windows -o user=utilisateur,pass=motdepasse

Envoyer un email en bash

Sans pièce jointe :

Avec un fichier en lieu et place du corps du mail (ici aussi) :

Pièce jointe avec un echo + mutt :

ou avec mutt + pièce jointe (sans echo) :

Pleins d'exemples ici

Mémo de scripts shell / bash

Informations relatives au système (matériel)

Je vous recommande de prendre connaissance de cette page.

Autres commandes à garder sous le coude

Voir chez CrouCrou

Toutes les commandes ?

Par ailleurs, si vous recherchez toutes les commandes fondamentales :

Sans bien sûr parler commandes dites "de base" : reboot, ping, nslookup, etc. Voici une carte heuristique des commandes Linux.

Systèmes AIX

Voir le mémo chez System-Linux.eu

Afficher le répertoire courant

[shell]pwd[/shell]

Auteur : Mr Xhark

Fondateur du blog et passionné par les nouvelles techno, suivez-moi sur twitter