Aide-mémoire des commandes GNU/Linux
Répertoires
pwd
Affiche le chemin absolu du répertoire courant (Print Working Directory).
$ pwd
/home/nicolas
cd [répertoire]
Change de répertoire (Change Directory). Va dans répertoire ou dans le répertoire de l'utilisateur s'il n'y a pas d'argument.
Si "-" est indiqué en argument, déplace dans le répertoire précédent.
$ pwd
/home/nicolas
$ cd /var/tmp
$ pwd
/var/tmp
$ cd ..
$ pwd
/var
$ cd
$ pwd
/home/nicolas
$ cd -
/var
$ pwd
/var
ls [fichier ...]
Liste le contenu des répertoires ou le nom des fichiers passés en arguments (liste le répertoire courant si pas d'argument).
-l : affichage détaillé (long)
-a : affichage aussi des fichiers cachés dont le nom commence par un point (all)
-i : affichage des numéros d'inodes (inode)
-d : affichage du nom du répertoire et non de son contenu (directory)
-t : trie l'affichage suivant la date de modification des fichiers (time)
-r : inverse le tri d'affichage (reverse)
-R : affichage du contenu de tous les sous répertoires (recursive)
$ ls
fic1 fic2 rep1
$ ls -a
. .. .bash_history .bash_profile .bashrc .viminfo fic1 fic2 rep1
$ ls -l
total 8
-rw-r--r-- 1 nicolas users 0 Dec 6 11:48 fic1
-rw-r--r-- 1 nicolas users 868 Dec 6 11:48 fic2
drwxr-xr-x 3 nicolas users 4096 Dec 6 11:48 rep1
$ ls -R
.:
fic1 fic2 rep1
./rep1:
ficA repA
./rep1/repA:
$ ls -ltr
total 8
-rw-r--r-- 1 nicolas users 0 Dec 6 11:48 fic1
drwxr-xr-x 3 nicolas users 4096 Dec 6 11:48 rep1
-rw-r--r-- 1 nicolas users 868 Dec 6 11:48 fic2
$ ls -l rep1
total 4
-rw-r--r-- 1 nicolas users 0 Dec 6 11:48 ficA
drwxr-xr-x 2 nicolas users 4096 Dec 6 11:42 repA
$ ls -ld rep1
drwxr-xr-x 3 nicolas users 4096 Dec 6 11:48 rep1
mkdir <répertoire ...>
Créé les répertoires (MaKe DIRectory) passés en arguments.
$ ls -l
total 0
$ mkdir rep1
$ ls -l
total 4
drwxr-xr-x 2 nicolas users 4096 Dec 6 11:41 rep1
$ mkdir rep1/repA rep2
$ ls -lR
.:
total 8
drwxr-xr-x 3 nicolas users 4096 Dec 6 11:42 rep1
drwxr-xr-x 2 nicolas users 4096 Dec 6 11:42 rep2
./rep1:
total 4
drwxr-xr-x 2 nicolas users 4096 Dec 6 11:42 repA
./rep1/repA:
total 0
./rep2:
total 0
rmdir <répertoire ...>
Supprime les répertoires (ReMove DIRectory) passés en arguments s'ils sont vides.
$ rmdir rep1 rep2
rmdir: `rep1': Directory not empty
$ ls -l
total 4
drwxr-xr-x 3 nicolas users 4096 Dec 6 11:42 rep1
Fichiers
cp <source ...> <destination>
Copie (CoPy) les fichiers source vers destination.
-i : demande confirmation avant écrasement (interactive)
-f : écrase sans demander confirmation (force)
-R ou -r : copie aussi les répertoires (recursive)
$ ls -l
total 8
-rw-r--r-- 1 nicolas users 0 Dec 6 11:48 fic1
-rw-r--r-- 1 nicolas users 868 Dec 6 11:48 fic2
drwxr-xr-x 3 nicolas users 4096 Dec 6 11:48 rep1
$ cp fic1 fic3
$ cp fic2 fic3
$ cp -i fic2 fic3
cp: overwrite `fic3'? o
$ cp rep1 rep2
cp: omitting directory `rep1'
$ cp -r rep1 rep2
$ cp -dpr rep1 /tmp
$ ls -l
total 16
-rw-r--r-- 1 nicolas users 0 Dec 6 11:48 fic1
-rw-r--r-- 1 nicolas users 868 Dec 6 11:48 fic2
-rw-r--r-- 1 nicolas users 868 Dec 6 14:08 fic3
drwxr-xr-x 3 nicolas users 4096 Dec 6 11:48 rep1
drwxr-xr-x 3 nicolas users 4096 Dec 6 14:09 rep2
$ ls -ld /tmp/rep1
drwxr-xr-x 3 nicolas users 4096 Dec 6 11:48 /tmp/rep1
Attention : sans l'option -R (ou -r), la commande cp ne pourra pas copier les répertoires ; il est nécessaire qu'elle travaille en "récursif" pour parcourir l'arborescence de fichiers sous le répertoire, et ainsi pouvoir copier les fichiers sous jacents.
mv <source ...> <destination>
Renomme/déplace (MoVe) les fichiers source vers destination.
-i : demande confirmation avant écrasement (interactive)
-f : écrase sans demander confirmation (force)
$ ls
fic1 fic2 fic3 rep1 rep2
$ ls rep2
ficA repA
$ mv fic* rep2
$ ls
rep1 rep2
$ ls rep2
fic1 fic2 fic3 ficA repA
$ mv rep1 rep2
$ ls
rep2
$ ls rep2
fic1 fic2 fic3 ficA rep1 repA
rm <fichier ...>
Supprime (ReMove) les fichiers passés en arguments.
-i : demande confirmation avant suppression (interactive)
-f : supprime sans demander confirmation (force)
-R : supprime aussi les répertoires (recursive)
$ ls -R .
.:
rep2
./rep2:
fic1 fic2 fic3 ficA rep1 repA
./rep2/rep1:
ficA repA
./rep2/rep1/repA:
./rep2/repA:
$ rm rep2/fic1
$ ls rep2
fic2 fic3 ficA rep1 repA
$ rm rep2/rep1
rm: `rep2/rep1' is a directory
$ rm -r rep2/rep1
$ ls rep2
fic2 fic3 ficA repA
ln <source> <destination>
Créé le lien (LiNk) destination vers le fichier source.
-s : créé un lien "symbolique" (soft) à la place d'un lien "dur" (hard)
$ echo coucou > fichier1
$ ls -l
total 4
-rw-r--r-- 1 nicolas users 7 Dec 6 14:24 fichier1
$ ln fichier1 fichier2
$ ln -s fichier1 fichier3
$ ls -l
total 8
-rw-r--r-- 2 nicolas users 7 Dec 6 14:24 fichier1
-rw-r--r-- 2 nicolas users 7 Dec 6 14:24 fichier2
lrwxrwxrwx 1 nicolas users 8 Dec 6 14:25 fichier3 -> fichier1
$ rm fichier1
$ ls -l
total 4
-rw-r--r-- 1 nicolas users 7 Dec 6 14:24 fichier2
lrwxrwxrwx 1 nicolas users 8 Dec 6 14:25 fichier3 -> fichier1
$ cat fichier2
coucou
$ cat fichier3
cat: fichier3: No such file or directory
touch <fichier ...>
Met à jour l'horodatage des fichiers passés en arguments ou créé ceux-ci s'ils n'existent pas.
$ ls -l
total 4
-rw-r--r-- 1 nicolas users 7 Dec 6 14:24 fichier
$ date
Mon Dec 6 14:30:02 CET 2004
$ touch fichier nouvfichier
$ ls -l
total 4
-rw-r--r-- 1 nicolas users 7 Dec 6 14:30 fichier
-rw-r--r-- 1 nicolas users 0 Dec 6 14:30 nouvfichier
type <cmd ...>
Indique comment chaque commande cmd doit être interprétée si elle est invoquée en ligne de commandes.
$ type ls cd passwd
ls is aliased to `ls --color=tty'
cd is a shell builtin
passwd is /usr/bin/passwd
which <cmd ...>
Retourne les chemins des binaires de chaque commande cmd passés en argument.
Ne prend pas en compte les commandes intégrées du shell et les alias.
$ which ls cd passwd
/bin/ls
/usr/bin/passwd
whereis <cmd ...>
Retourne les chemins du binaire, des sources et de la page de manuel des commandes passées en argument.
Comme pour la commande which, whereis ne tient pas compte de l'interprétation du shell.
$ whereis ls cd passwd
ls: /bin/ls /usr/share/man/man1/ls.1.gz
cd:
passwd: /usr/bin/passwd /etc/passwd /usr/share/man/man1/passwd.1.gz /usr/share/man/man5/passwd.5.gz
find <chemin(s)> <critère(s)> <action(s)>
Recherche de fichiers multi-critères :
- recherche récursive dans le(s) répertoire(s) indiqué(s) (chemin(s))
- les principaux critères (critère(s)) sont :
-name '<motif>'
-size <[+|-]taille>
-mtime <[+|-]date>
-user <nom|UID>
-newer <fichier référence>
- les principales actions (action(s)) sont :
-print
-ls
-exec <commande shell avec {} pour spécifier le fichier trouvé> \;
-ok <commande shell avec {} pour spécifier le fichier trouvé> \;
$ find /home /usr -name 'ab*' -print 2> /dev/null
/usr/share/vim/vim61/ftplugin/abaqus.vim
/usr/share/vim/vim61/syntax/abaqus.vim
/usr/share/vim/vim61/syntax/abc.vim
/usr/share/vim/vim61/syntax/abel.vim
$ find /home /usr -name 'ab*' -exec basename {} \; 2> /dev/null
abaqus.vim
abaqus.vim
abc.vim
abel.vim
updatedb
Création et mise à jour de la base de données utilisée par la commande locate.
# updatedb
locate
Recherche de fichiers suivant leur nom ; cette commande est plus rapide que la commande find car elle utilise une base de données des fichiers présents sur le système (voir la commande updatedb). Cependant, si la base de données des fichiers n'est pas à jour, le résultat de la recherche n'affiche pas tous les fichiers existants.
$ locate service
/etc/services
/usr/share/man/man5/services.5.gz
Traitement de fichiers et filtres
cat [fichier ...]
Affiche le contenu des fichiers texte passés en arguments.
$ cat fictexte
Je vis que la Terre ayant besoin de la lumière,
de la chaleur, et de l'influence de ce grand feu,
elle se tourne autour de lui pour recevoir
également en toutes ses parties cette vertu qui
la conserve.
Savinien de CYRANO DE BERGERAC
$
tac [fichier ...]
Affiche le contenu inversé (de la dernière ligne à la première) des fichiers texte passés en arguments.
$ tac fictexte
Savinien de CYRANO DE BERGERAC
la conserve.
également en toutes ses parties cette vertu qui
elle se tourne autour de lui pour recevoir
de la chaleur, et de l'influence de ce grand feu,
Je vis que la Terre ayant besoin de la lumière,
$
nl [fichier ...]
Affiche le contenu des fichiers texte passés en arguments en numérotant les lignes.
$ nl fictexte
1 Je vis que la Terre ayant besoin de la lumière,
2 de la chaleur, et de l'influence de ce grand feu,
3 elle se tourne autour de lui pour recevoir
4 également en toutes ses parties cette vertu qui
5 la conserve.
6 Savinien de CYRANO DE BERGERAC
$
more [fichier ...]
Affiche page par page le contenu des fichiers texte passés en arguments.
Pour afficher le contenu d'un fichier :
$ more /etc/services
# /etc/services:
# $Id: services,v 1.32 2003/01/09 17:56:30 dwalsh Exp $
#
# Network services, Internet style
#
# Note that it is presently the policy of IANA to assign a single well-known
# port number for both TCP and UDP; hence, most entries here have two entries
# even if the protocol doesn't support UDP operations.
# Updated from RFC 1700, ``Assigned Numbers'' (October 1994). Not all ports
# are included, only the more common ones.
#
# The latest IANA port assignments can be gotten from
# http://www.iana.org/assignments/port-numbers
# The Well Known Ports are those from 0 through 1023.
# The Registered Ports are those from 1024 through 49151
# The Dynamic and/or Private Ports are those from 49152 through 65535
#
# Each line describes one service, and is of the form:
#
# service-name port/protocol [aliases ...] [# comment]
--Encore--(4%)
Dans un tube, pour visualiser le résultat d'une commande :
$ ps -ef | more
UID PID PPID C STIME TTY TIME CMD
root 1 0 0 Oct23 ? 00:00:19 init [3]
root 2 1 0 Oct23 ? 00:00:00 [keventd]
root 3 1 0 Oct23 ? 00:00:00 [ksoftirqd_CPU0]
root 4 1 0 Oct23 ? 00:00:00 [ksoftirqd_CPU1]
root 5 1 0 Oct23 ? 00:00:04 [kswapd]
root 6 1 0 Oct23 ? 00:00:00 [bdflush]
root 7 1 0 Oct23 ? 00:01:10 [kupdated]
root 8 1 0 Oct23 ? 00:00:00 [scsi_eh_0]
root 9 1 0 Oct23 ? 00:00:00 [khubd]
root 11 1 0 Oct23 ? 00:01:14 [kjournald]
root 113 1 0 Oct23 ? 00:00:00 [kjournald]
root 114 1 0 Oct23 ? 00:00:46 [kjournald]
root 115 1 0 Oct23 ? 00:18:06 [kjournald]
root 116 1 0 Oct23 ? 00:01:08 [kjournald]
root 484 1 0 Oct23 ? 00:00:03 /usr/sbin/sshd
root 493 1 0 Oct23 ? 00:16:07 syslogd -m 0
root 497 1 0 Oct23 ? 00:00:00 klogd -x
rpc 507 1 0 Oct23 ? 00:00:00 portmap
rpcuser 526 1 0 Oct23 ? 00:00:00 rpc.statd
ldap 576 1 0 Oct23 ? 04:21:33 /usr/sbin/slapd -u ldap -h ldap:
--Encore--
less [fichier ...]
Affiche page par page le contenu des fichiers texte passés en arguments.
$ less /etc/services
# /etc/services:
# $Id: services,v 1.32 2003/01/09 17:56:30 dwalsh Exp $
#
# Network services, Internet style
#
# Note that it is presently the policy of IANA to assign a single well-known
# port number for both TCP and UDP; hence, most entries here have two entries
# even if the protocol doesn't support UDP operations.
# Updated from RFC 1700, ``Assigned Numbers'' (October 1994). Not all ports
# are included, only the more common ones.
#
# The latest IANA port assignments can be gotten from
# http://www.iana.org/assignments/port-numbers
# The Well Known Ports are those from 0 through 1023.
# The Registered Ports are those from 1024 through 49151
# The Dynamic and/or Private Ports are those from 49152 through 65535
#
# Each line describes one service, and is of the form:
#
# service-name port/protocol [aliases ...] [# comment]
tcpmux 1/tcp # TCP port service multiplexer
/etc/services
wc [fichier ...]
Affiche le nombre de lignes, de mots et de caractères (Word Count) contenus dans les fichiers passés en arguments.
-l : affiche uniquement le nombre de lignes (line)
-w : affiche uniquement le nombre de mots (word)
-c : affiche uniquement le nombre de caractères (character)
$ wc /etc/services
569 2805 19935 /etc/services
$ ls | wc -l
5
od [fichier ...]
Affiche (en octal par défaut) le contenu des fichiers binaires passés en arguments (Octal Dump).
-x : affiche les données en hexadécimal
Affichage en octal du fichier /bin/ls :
$ od /bin/ls
0000000 042577 043114 000401 000001 000000 000000 000000 000000
0000020 000002 000003 000001 000000 116300 004004 000064 000000
0000040 057254 000001 000000 000000 000064 000040 000010 000050
0000060 000037 000036 000006 000000 000064 000000 100064 004004
0000100 100064 004004 000400 000000 000400 000000 000005 000000
0000120 000004 000000 000003 000000 000464 000000 100464 004004
0000140 100464 004004 000023 000000 000023 000000 000004 000000
0000160 000001 000000 000001 000000 000000 000000 100000 004004
0000200 100000 004004 045073 000001 045073 000001 000005 000000
0000220 010000 000000 000001 000000 050000 000001 150000 004005
...
Affichage en hexadécimal du fichier /bin/ls :
$ od -x /bin/ls
0000000 457f 464c 0101 0001 0000 0000 0000 0000
0000020 0002 0003 0001 0000 9cc0 0804 0034 0000
0000040 5eac 0001 0000 0000 0034 0020 0008 0028
0000060 001f 001e 0006 0000 0034 0000 8034 0804
0000100 8034 0804 0100 0000 0100 0000 0005 0000
0000120 0004 0000 0003 0000 0134 0000 8134 0804
0000140 8134 0804 0013 0000 0013 0000 0004 0000
0000160 0001 0000 0001 0000 0000 0000 8000 0804
0000200 8000 0804 4a3b 0001 4a3b 0001 0005 0000
0000220 1000 0000 0001 0000 5000 0001 d000 0805
...
La première colonne correspond au décalage par rapport au début du fichier ; les données sont représentés dans les colonnes suivantes.
strings [fichier ...]
Affiche le contenu texte des fichiers binaires passés en arguments.
$ strings /bin/ls
/lib/ld-linux.so.2
libtermcap.so.2
_DYNAMIC
_init
tgetent
_fini
_GLOBAL_OFFSET_TABLE_
_Jv_RegisterClasses
tgetstr
__gmon_start__
libc.so.6
strcpy
ioctl
stdout
...
split -b <taille>k <src> <dst>
Découpe le fichier src en plusieurs fichiers de la taille spécifiée (en Ko ici) nommés dstaa, dstab, dstac, ...
On peut ensuite reconstituer le fichier original à l'aide de la commande cat.
$ ls -l
total 1272
-rw-r--r-- 1 nicolas users 1296504 Dec 6 15:45 grosfic
$ split -b 500k grosfic archive_
$ ls -l
total 2552
-rw-r--r-- 1 nicolas users 512000 Dec 6 15:46 archive_aa
-rw-r--r-- 1 nicolas users 512000 Dec 6 15:46 archive_ab
-rw-r--r-- 1 nicolas users 272504 Dec 6 15:46 archive_ac
-rw-r--r-- 1 nicolas users 1296504 Dec 6 15:45 grosfic
$ cat archive_* > grosfic2
$ ls -l
total 3824
-rw-r--r-- 1 nicolas users 512000 Dec 6 15:46 archive_aa
-rw-r--r-- 1 nicolas users 512000 Dec 6 15:46 archive_ab
-rw-r--r-- 1 nicolas users 272504 Dec 6 15:46 archive_ac
-rw-r--r-- 1 nicolas users 1296504 Dec 6 15:45 grosfic
-rw-r--r-- 1 nicolas users 1296504 Dec 6 15:46 grosfic2
join <fichier1> <fichier2>
Effectue une jointure (dans le sens d'une base de données relationnelle) entre deux fichiers texte.
paste <fichier1> <fichier2> <...>
Fusionne ligne par ligne les fichiers passés en argument.
gzip <fichier>
Compresse le fichier fichier au format GNU Zip ; par défaut, le fichier compressé est nommé fichier.gz et l'original est supprimé.
Voir la commande gunzip pour décompresser le fichier généré.
$ ls -l
total 1144
-rw-r--r-- 1 nicolas users 1166532 Dec 6 16:21 fichier
$ gzip fichier
$ ls -l
total 140
-rw-r--r-- 1 nicolas users 137644 Dec 6 16:21 fichier.gz
gunzip <fichier[.gz]>
Décompresse le fichier fichier.gz qui est au format GNU Zip ; par défaut, l'extension .gz est supprimée dans le nom du fichier non compressé et le fichier original compressé est supprimé.
Il n'est pas obligatoire de préciser l'extension .gz dans le nom du fichier passé en argument.
Voir la commande gzip pour compresser un fichier.
$ ls -l
total 140
-rw-r--r-- 1 nicolas users 137644 Dec 6 16:21 fichier.gz
$ gunzip fichier
$ ls -l
total 1144
-rw-r--r-- 1 nicolas users 1166532 Dec 6 16:21 fichier
tr <liste1> <liste2>
tr -s <liste>
tr -d <liste>
tr -s <liste>
tr -d <liste>
Substitue un à un les caractères de la liste1 par ceux de la liste2 dans le texte envoyé sur l'entrée standard de la commande.
-d : supprime les caractères de la liste dans le texte envoyé sur l'entrée standard de la commande.
-s : supprime les doublons des caractères de la liste dans le texte envoyé sur l'entrée standard de la commande.
$ echo "une chaine de caracteres" | tr "ace" "AkE"
unE khAinE dE kArAktErEs
$ ls -l
total 1148
-rw-r--r-- 1 nicolas users 1166532 Dec 6 16:21 fichier
drwxr-xr-x 2 nicolas users 4096 Dec 6 16:52 rep
$ ls -l | tr -d " "
total1148
-rw-r--r--1nicolasusers1166532Dec616:21fichier
drwxr-xr-x2nicolasusers4096Dec616:52rep
$ ls -l | tr -s " "
total 1148
-rw-r--r-- 1 nicolas users 1166532 Dec 6 16:21 fichier
drwxr-xr-x 2 nicolas users 4096 Dec 6 16:52 rep
grep <regexp> [fichier ...]
Affiche uniquement les lignes, des fichiers passés en argument, correspondantes à l'expression rationnelle (ou expression régulière) regexp.
-v : inverse le résultat de la commande (affiche seulement les lignes ne correspondant pas à regexp)
-c : retourne le nombre de correspondances
-n : affiche les numéros des lignes correspondantes
-l : affiche les noms des fichiers contenant des lignes correpondant à regexp
-i : ne tient pas compte de la casse des caractères
sed <instr ...> [fichier ...]
Applique les instructions sed sur les fichiers passés en arguments.
-f instr.sed : utilise les instructions sed contenues dans le fichier instr.sed
awk <instr ...> [fichier ...]
Applique les instructions awk sur les fichiers passés en arguments.
-f instr.awk : utilise les instructions awk contenues dans le fichier instr.awk
cut -d<délimiteur> -f<champ(s)> [fichier]
cut -c<colonne(s)> [fichier]
cut -c<colonne(s)> [fichier]
Affiche les champs spécifiés avec l'option -f et séparés par le délimiteur indiqué après l'option -d, ou affiche les colonnes de caractères indiquées après l'option -c.
Pour afficher les 3ème et 6ème colonnes du fichier /etc/passwd :
$ cat /etc/passwd
root:x:0:0:root:/root:/bin/bash
daemon:x:1:1:daemon:/usr/sbin:/bin/sh
bin:x:2:2:bin:/bin:/bin/sh
sys:x:3:3:sys:/dev:/bin/sh
nobody:x:65534:65534:nobody:/home:/bin/sh
sshd:x:100:65534::/var/run/sshd:/bin/false
nicolas:x:1000:100::/home/nicolas:/bin/bash
$ cut -d":" -f3,6 /etc/passwd
0:/root
1:/usr/sbin
2:/bin
3:/dev
65534:/home
100:/var/run/sshd
1000:/home/nicolas
Dans un tube, pour filtrer le résultat d'une commande :
$ ls -l
total 1148
-rw-r--r-- 1 nicolas users 1166532 Dec 6 16:21 fichier
drwxr-xr-x 2 nicolas users 4096 Dec 6 16:52 rep
$ ls -l | cut -c-10,16-23,56-
total 1148
-rw-r--r-- nicolas fichier
drwxr-xr-x nicolas rep
head -<n> [fichier]
Affiche les n premières lignes (ou les 10 premières si n n'est pas spécifié).
$ cat numeros
ligne 1
ligne 2
ligne 3
ligne 4
ligne 5
ligne 6
ligne 7
ligne 8
ligne 9
ligne 10
ligne 11
$ head -3 numeros
ligne 1
ligne 2
ligne 3
tail -<n> [fichier]
tail +<n> [fichier]
tail +<n> [fichier]
Avec -, affiche les n dernières lignes (ou les 10 dernières si n n'est pas spécifié).
Avec +, affiche à partir de la nième ligne.
$ cat numeros
ligne 1
ligne 2
ligne 3
ligne 4
ligne 5
ligne 6
ligne 7
ligne 8
ligne 9
ligne 10
ligne 11
$ tail -3 numeros
ligne 9
ligne 10
ligne 11
$ tail +7 numeros
ligne 7
ligne 8
ligne 9
ligne 10
ligne 11
sort [fichier ...]
Trie les lignes.
file [fichier ...]
Retourne le type des fichiers passés en arguments.
$ file /home /bin/ls /etc/passwd /usr/X11R6/bin/startx
/home: symbolic link to `/ramdisk/home'
/bin/ls: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV),
for GNU/Linux 2.2.0, dynamically linked (uses shared libs), stripped
/etc/passwd: ASCII text
/usr/X11R6/bin/startx: Bourne shell script text executable
Documentation
man [section] <argument>
Affiche la page de manuel électronique dont le nom est argument (se trouvant dans la section du manuel éventuellement spécifié).
-k : retourne le nom des pages de manuel contenant argument
Par exemple :
$ man 7 signal
Qui affiche :
SIGNAL(7) Manuel de l’administrateur Linux SIGNAL(7)
NOM
signal - Liste des signaux disponibles.
DESCRIPTION
Linux supporte supporte à la fois les signaux POSIX classiques ("sig-
naux standards") et les signaux POSIX temps-réel.
Signaux standards
Linux supporte les signaux standards indiqués ci-dessous. Plusieurs
d’entre-eux dépendent de l’architecture, comme on le voit dans la
colonne "Valeur". Lorsque trois valeurs sont indiquées, la première
correspond normalement aux architectures Alpha et Sparc, la seconde
pour les ix86, PPC et la dernière pour les Mips. Un - dénote un signal
absent pour l’architecture correspondante.
Les symboles de la colonne "Action" ont la signification suivante :
Term Par défaut, terminer le processus.
Ign Par défaut, ignorer le signal.
:
La navigation dans une page de manuel électronique se fait de la même manière que dans l'éditeur de texte Vi.
apropos <argument>
Idem que man -k <argument>
$ apropos signal
alarm (2) - Programmer un réveil (timer) pour l'émission d'un signal
alarm (2) - set an alarm clock for delivery of a signal
bosskill (8) - Envoyer un signal éventuellement mortel à votre chef
gsignal (3) - software signal facility
kill (1) - Envoyer un signal à un processus
kill (2) - Envoyer un signal à un processus
kill (2) - send signal to a process
killall (1) - Envoyer un signal à des processus indiqués par leurs noms
...
Les chiffres entre parenthèses indiquent la section du manuel électronique qui contient la page indiquée.
Droits
chmod <mode> <fichier ...>
Modifie les droits d'accès (CHange MODe) aux fichiers passés en arguments suivant le mode (notation symbolique ou octale).
-R : applique les modifications à toute l'arborescence (recursive).
$ ls -l
total 1148
-rw-r--r-- 1 nicolas users 1166532 Dec 6 16:21 fichier
drwxr-xr-x 2 nicolas users 4096 Dec 6 16:52 rep
$ chmod ug+x fichier
$ chmod 754 rep
$ ls -l
total 1148
-rwxr-xr-- 1 nicolas users 1166532 Dec 6 16:21 fichier
drwxr-xr-- 2 nicolas users 4096 Dec 6 16:52 rep
umask [mode]
Affiche le masque binaire déterminant les droits par défaut sur les nouveaux fichiers créés (sans argument) ou modifie ce masque (argument en notation octale).
$ umask
0022
$ touch fic1
$ mkdir rep1
$ ls -l
total 4
-rw-r--r-- 1 nicolas users 0 Mar 2 12:31 fic1
drwxr-xr-x 2 nicolas users 4096 Mar 2 12:31 rep1
$ umask 0027
$ touch fic2
$ mkdir rep2
$ ls -l
total 8
-rw-r--r-- 1 nicolas users 0 Mar 2 12:31 fic1
-rw-r----- 1 nicolas users 0 Mar 2 12:32 fic2
drwxr-xr-x 2 nicolas users 4096 Mar 2 12:31 rep1
drwxr-x--- 2 nicolas users 4096 Mar 2 12:32 rep2
Gestion des comptes utilisateurs
passwd [utilisateur]
Change le mot de passe du compte utilisateur (mot de passe de l'utilisateur connecté si pas d'argument).
-l : verrouille le compte passé en argument (lock)
-u : débloque le compte passé en argument (unlock)
-S : indique l'état du compte passé en argument (status)
Processus
ps
Liste les processus (programmes en cours d'exécution).
-ef : affiche tous les processus avec des statistiques supplémentaires
aux : affiche tous les processus avec des statistiques supplémentaires
$ ps -ef
UID PID PPID C STIME TTY TIME CMD
root 1 0 0 04:42 ? 00:00:05 init [2]
root 2 1 0 04:42 ? 00:00:00 [keventd]
root 3 0 0 04:42 ? 00:00:00 [ksoftirqd_CPU0]
root 4 0 0 04:42 ? 00:00:00 [kswapd]
root 5 0 0 04:42 ? 00:00:00 [bdflush]
root 6 0 0 04:42 ? 00:00:08 [kupdated]
root 7 1 0 04:42 ? 00:00:00 [i2oevtd]
root 8 1 0 04:42 ? 00:00:08 [kjournald]
root 67 1 0 04:42 ? 00:00:03 [kjournald]
root 68 1 0 04:42 ? 00:00:02 [kjournald]
root 136 1 0 04:42 ? 00:00:01 /sbin/syslogd
root 139 1 0 04:42 ? 00:00:00 /sbin/klogd
root 144 1 0 04:42 ? 00:00:00 /usr/sbin/inetd
root 151 1 0 04:42 ? 00:00:00 /usr/sbin/sshd
root 154 1 0 04:42 ? 00:00:00 /usr/sbin/cron
root 158 1 0 04:42 tty2 00:00:00 /sbin/getty 38400 tty2
root 159 1 0 04:42 tty3 00:00:00 /sbin/getty 38400 tty3
root 160 1 0 04:42 tty4 00:00:00 /sbin/getty 38400 tty4
root 161 1 0 04:42 tty5 00:00:00 /sbin/getty 38400 tty5
root 162 1 0 04:42 tty6 00:00:00 /sbin/getty 38400 tty6
root 465 1 0 07:49 tty1 00:00:00 /sbin/getty 38400 tty1
root 2503 151 0 11:46 ? 00:00:00 /usr/sbin/sshd
nicolas 2505 2503 0 11:47 ? 00:00:02 /usr/sbin/sshd
nicolas 2506 2505 0 11:47 pts/0 00:00:00 -bash
nicolas 2517 2506 0 12:09 pts/0 00:00:00 ps -ef
$ ps aux
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.3 1272 484 ? S 04:42 0:05 init [2]
root 2 0.0 0.0 0 0 ? SW 04:42 0:00 [keventd]
root 3 0.0 0.0 0 0 ? SWN 04:42 0:00 [ksoftirqd_CPU0]
root 4 0.0 0.0 0 0 ? SW 04:42 0:00 [kswapd]
root 5 0.0 0.0 0 0 ? SW 04:42 0:00 [bdflush]
root 6 0.0 0.0 0 0 ? SW 04:42 0:08 [kupdated]
root 7 0.0 0.0 0 0 ? SW 04:42 0:00 [i2oevtd]
root 8 0.0 0.0 0 0 ? SW 04:42 0:08 [kjournald]
root 67 0.0 0.0 0 0 ? SW 04:42 0:03 [kjournald]
root 68 0.0 0.0 0 0 ? SW 04:42 0:02 [kjournald]
root 136 0.0 0.4 1344 596 ? S 04:42 0:01 /sbin/syslogd
root 139 0.0 0.9 1940 1152 ? S 04:42 0:00 /sbin/klogd
root 144 0.0 0.3 1248 428 ? S 04:42 0:00 /usr/sbin/inetd
root 151 0.0 0.9 2784 1208 ? S 04:42 0:00 /usr/sbin/sshd
root 154 0.0 0.5 1652 684 ? S 04:42 0:00 /usr/sbin/cron
root 158 0.0 0.3 1252 468 tty2 S 04:42 0:00 /sbin/getty 38400
root 159 0.0 0.3 1252 468 tty3 S 04:42 0:00 /sbin/getty 38400
root 160 0.0 0.3 1252 468 tty4 S 04:42 0:00 /sbin/getty 38400
root 161 0.0 0.3 1252 468 tty5 S 04:42 0:00 /sbin/getty 38400
root 162 0.0 0.3 1252 468 tty6 S 04:42 0:00 /sbin/getty 38400
root 465 0.0 0.3 1252 468 tty1 S 07:49 0:00 /sbin/getty 38400
root 2503 0.0 1.3 5704 1676 ? S 11:46 0:00 /usr/sbin/sshd
nicolas 2505 0.1 1.4 5740 1792 ? S 11:46 0:02 /usr/sbin/sshd
nicolas 2506 0.0 1.0 2224 1260 pts/0 S 11:46 0:00 -bash
nicolas 2518 0.0 1.2 3564 1584 pts/0 R 12:09 0:00 ps aux
pstree
Liste les processus de façon arborescente.
-p : affiche aussi les PID des processus
$ pstree
init-+-cron
|-6*[getty]
|-i2oevtd
|-inetd
|-keventd
|-3*[kjournald]
|-klogd
|-sshd---sshd---sshd---bash---pstree
`-syslogd
$ pstree -p
init(1)-+-cron(154)
|-getty(158)
|-getty(159)
|-getty(160)
|-getty(161)
|-getty(162)
|-getty(465)
|-i2oevtd(7)
|-inetd(144)
|-keventd(2)
|-kjournald(8)
|-kjournald(67)
|-kjournald(68)
|-klogd(139)
|-sshd(151)---sshd(2503)---sshd(2505)---bash(2506)---pstree(2520)
`-syslogd(136)
jobs
Liste les "jobs" (processus lancés par le shell courant).
$ sleep 10m &
[1] 2523
$ sleep 20m &
[2] 2524
$ sleep 30m &
[3] 2525
$ jobs
[1] Running sleep 10m &
[2]- Running sleep 20m &
[3]+ Running sleep 30m &
bg %<job>
Relance le "job" job en arrière plan.
$ sleep 40m
[Ctrl + z pour suspendre le processus lancé en avant plan]
[4]+ Stopped sleep 40m
$ bg %4
[4]+ sleep 40m &
$ jobs
[1] Running sleep 10m &
[2] Running sleep 20m &
[3]- Running sleep 30m &
[4]+ Running sleep 40m &
fg %<job>
Relance le "job" job en avant plan.
$ jobs
[1] Running sleep 10m &
[2] Running sleep 20m &
[3]- Running sleep 30m &
[4]+ Running sleep 40m &
$ fg %4
sleep 40m
kill <signal> %<job>
Envoi le signal signal au "job" job.
kill <signal> <pid>
Envoi le signal signal au processus dont le PID est pid.
nohup <cmd> &
Exécute la commande cmd en tâche de fond qui survivra à la déconnexion de l'utilisateur (no hang up).
nice [gentillesse] <cmd> &
Exécute la commande cmd avec la priorité définie par la gentillesse (nice) spécifiée en argument.
renice <gentillesse> <PID>
Redéfini la priorité du processus identifié par son PID suivant la gentillesse (nice) spécifiée.
top
Affiche une liste — rafraîchie régulièrement — des processus en cours d'exécution et permet de les contrôler (équivalent de kill et renice) ; affiche aussi des statistiques d'utilisation de la mémoire.
11:47:56 up 7:05, 2 users, load average: 0.03, 0.01, 0.00
28 processes: 27 sleeping, 1 running, 0 zombie, 0 stopped
CPU states: 0.1% user, 0.3% system, 0.0% nice, 99.6% idle
Mem: 125896K total, 64268K used, 61628K free, 15068K buffers
Swap: 498004K total, 0K used, 498004K free, 32608K cached
PID USER PRI NI SIZE RSS SHARE STAT %CPU %MEM TIME COMMAND
2510 nicolas 17 0 928 928 748 R 2.8 0.7 0:00 top
1 root 8 0 484 484 424 S 0.0 0.3 0:05 init
2 root 9 0 0 0 0 SW 0.0 0.0 0:00 keventd
3 root 19 19 0 0 0 SWN 0.0 0.0 0:00 ksoftirqd_CPU0
4 root 9 0 0 0 0 SW 0.0 0.0 0:00 kswapd
5 root 9 0 0 0 0 SW 0.0 0.0 0:00 bdflush
6 root 11 0 0 0 0 SW 0.0 0.0 0:08 kupdated
7 root 9 0 0 0 0 SW 0.0 0.0 0:00 i2oevtd
8 root 9 0 0 0 0 SW 0.0 0.0 0:08 kjournald
67 root 9 0 0 0 0 SW 0.0 0.0 0:03 kjournald
68 root 9 0 0 0 0 SW 0.0 0.0 0:02 kjournald
136 root 9 0 596 596 488 S 0.0 0.4 0:01 syslogd
139 root 9 0 1152 1152 408 S 0.0 0.9 0:00 klogd
144 root 9 0 428 428 376 S 0.0 0.3 0:00 inetd
151 root 9 0 1208 1208 1080 S 0.0 0.9 0:00 sshd
154 root 8 0 684 684 564 S 0.0 0.5 0:00 cron
158 root 9 0 468 468 408 S 0.0 0.3 0:00 getty
159 root 9 0 468 468 408 S 0.0 0.3 0:00 getty
160 root 9 0 468 468 408 S 0.0 0.3 0:00 getty
161 root 9 0 468 468 408 S 0.0 0.3 0:00 getty
162 root 9 0 468 468 408 S 0.0 0.3 0:00 getty
465 root 9 0 468 468 408 S 0.0 0.3 0:00 getty
2152 root 9 0 1676 1676 1516 S 0.0 1.3 0:00 sshd
2154 nicolas 9 0 1792 1792 1604 S 0.0 1.4 0:00 sshd
2155 nicolas 9 0 1256 1256 1024 S 0.0 0.9 0:00 bash
2503 root 9 0 1676 1676 1516 S 0.0 1.3 0:00 sshd
2505 nicolas 10 0 1792 1792 1604 S 0.0 1.4 0:00 sshd
2506 nicolas 12 0 1260 1260 1024 S 0.0 1.0 0:00 bash
Temps
date
Affiche ou modifie la date système.
+"FORMAT" : affiche la date suivant un format définit par une chaîne de caractères composée de séquences représentant des éléments de la date.
-s "mm/jj/aaaa hh:mm:ss" : définit la date système (droits administrateur obligatoires).
$ date
Mon Dec 6 17:06:33 CET 2004
$ date +"nous sommes le %d/%m/%Y"
nous sommes le 06/12/2004
# date
Mon Dec 6 17:07:07 CET 2004
# date -s "03/02/2005 10:30:00"
Wed Mar 2 10:30:00 CET 2005
# date
Wed Mar 2 10:30:02 CET 2005
sleep <durée>
Attend sans rien faire autant de temps que spécifié en argument. L'unité par défaut est la seconde.
$ sleep 3 # attend 3 secondes
$ sleep 3s # idem que la ligne précédente
$ sleep 3m # attend 3 minutes
$ sleep 3h # attend 3 heures
$ sleep 3d # attend 3 jours
cal [[mois] année]
Affiche le calendrier du mois en cours (pas d'argument), de l'année en cours (un argument) ou du mois et de l'année spécifiés (deux arguments).
Le mois en cours (en date du 17/05/2006) :
$ cal
Mai 2006
di lu ma me je ve sa
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31
Le mois d'avril 2006 (attention à l'année 06 signifie l'an 6 après JC !) :
$ cal 04 06
Avril 6
di lu ma me je ve sa
1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30
$ cal 04 2006
Avril 2006
di lu ma me je ve sa
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30
L'année 2006 complète :
$ cal 2006
2006
Janvier Février Mars
di lu ma me je ve sa di lu ma me je ve sa di lu ma me je ve sa
1 2 3 4 5 6 7 1 2 3 4 1 2 3 4
8 9 10 11 12 13 14 5 6 7 8 9 10 11 5 6 7 8 9 10 11
15 16 17 18 19 20 21 12 13 14 15 16 17 18 12 13 14 15 16 17 18
22 23 24 25 26 27 28 19 20 21 22 23 24 25 19 20 21 22 23 24 25
29 30 31 26 27 28 26 27 28 29 30 31
Avril Mai Juin
di lu ma me je ve sa di lu ma me je ve sa di lu ma me je ve sa
1 1 2 3 4 5 6 1 2 3
2 3 4 5 6 7 8 7 8 9 10 11 12 13 4 5 6 7 8 9 10
9 10 11 12 13 14 15 14 15 16 17 18 19 20 11 12 13 14 15 16 17
16 17 18 19 20 21 22 21 22 23 24 25 26 27 18 19 20 21 22 23 24
23 24 25 26 27 28 29 28 29 30 31 25 26 27 28 29 30
...
Surveillance
who
Liste les utilisateurs connectés au système.
who am i
Liste l'utilisateur actuellement connecté au système.
whoami
Retourne le login de l'utilisateur actuellement connecté au système.
finger [utilisateur ...]
Liste les utilisateurs connectés au système (pas d'argument) ou détaille les comptes des utilisateurs passés en arguments.
Communication
write [utilisateur[@hôte]]
Affiche un message sur le terminal de l'utilisateur passé en argument.
wall
Affiche un message sur le terminal des utilisateurs connectés.
mail [utilisateur[@hôte]]
Lit la boîte aux lettres de l'utilisateur connecté (pas d'argument) ou envoi un message électronique dans la boîte aux lettres de l'utilisateur passé en argument.
talk
Établi une session de messagerie instantanée (chat) avec l'utilisateur passé en argument.
mesg
Affiche si l'utilisateur actuellement connecté accepte ou non les messages provenant d'autres utilisateurs.
mesg y
Autorise les messages provenant d'autres utilisateurs.
mesg n
Refuse les messages provenant d'autres utilisateurs.
Divers
clear
Efface l'écran du terminal.
echo [argument ...]
Affiche sur la sortie standard les chaînes de caractères passées en arguments, séparées par un espace.
exit [code_retour]
Quitte le shell en cours avec le code retour passé en argument ; par défaut exit retourne le code retour 0.
logout
Déconnecte l'utilisateur.
alias [nom='cmd']
Affiche les alias définis dans l'environnement shell actuel (pas d'argument) ou en défini un nouveau.
unalias <nom>
Supprime l'alias de l'environnement shell actuel.