« Shell » : différence entre les versions
(balises code) |
|||
(10 versions intermédiaires par 4 utilisateurs non affichées) | |||
Ligne 1 : | Ligne 1 : | ||
[[ | [[Catégorie:Commandes Unix]] | ||
[[Catégorie:Administration système]] | |||
= Le shell ou le retour du C:\> ! (et les commandes) = | = Le shell ou le retour du C:\> ! (et les commandes) = | ||
par [[Utilisateur:LeaJice|Jean-Christophe]], complété par [mailto:SPI.MJ%20%3Cspi.mj%20chez%20wanadoo.fr%3E Marc] et [[Utilisateur:Ennael|Anne]] | |||
Le shell, un environnement écrit au temps ou les hommes étaient des hommes :-) | |||
== Introduction == | == Introduction == | ||
Ligne 11 : | Ligne 14 : | ||
Bref, le shell c'est le bon vieux ''mode texte'', mon copain le ''prompt'', qui sous Linux revêt une importance capitale. En effet, la philosophie Unix veut que toute action puisse être réalisée en ligne de commande, avant d'être accessible dans une boîte de dialogue. Ainsi de nombreuses applications X ne sont en fait que des ''front ends'' (des façades) à des applications en ligne de commande, se contentant de construire la bonne ligne de commande à partir de vos clics (XCDRoast / cdrecord, mkisofs, etc. ; kppp / pppd ; etc.). | Bref, le shell c'est le bon vieux ''mode texte'', mon copain le ''prompt'', qui sous Linux revêt une importance capitale. En effet, la philosophie Unix veut que toute action puisse être réalisée en ligne de commande, avant d'être accessible dans une boîte de dialogue. Ainsi de nombreuses applications X ne sont en fait que des ''front ends'' (des façades) à des applications en ligne de commande, se contentant de construire la bonne ligne de commande à partir de vos clics (XCDRoast / cdrecord, mkisofs, etc. ; kppp / pppd ; etc.). | ||
Comme Linux prône le règne de la liberté, vous n'avez pas qu'un seul ''shell'' disponible. Vous pouvez utiliser '''bash''', '''tcsh''', '''ksh''', '''ash''', '''sh''', '''csh''', etc. Néanmoins, la plupart des distributions actuelles proposent '''bash''' par défaut, et je vous recommande donc de l'utiliser, surtout si vous débutez sous Unix et que vous n'avez pas encore d'habitudes. Si plus tard, vous tombez sur un ordinateur ne disposant que de tcsh, ne vous inquiétez pas : la différence n'est pas flagrante, et vous pourrez toujours consulter "< | Comme Linux prône le règne de la liberté, vous n'avez pas qu'un seul ''shell'' disponible. Vous pouvez utiliser '''bash''', '''tcsh''', '''ksh''', '''ash''', '''sh''', '''csh''', etc. Néanmoins, la plupart des distributions actuelles proposent '''bash''' par défaut, et je vous recommande donc de l'utiliser, surtout si vous débutez sous Unix et que vous n'avez pas encore d'habitudes. Si plus tard, vous tombez sur un ordinateur ne disposant que de tcsh, ne vous inquiétez pas : la différence n'est pas flagrante, et vous pourrez toujours consulter "<b>man tcsh</b>" ! <br />''à noter que le choix du shell pour un utilisateur se configure dans <b>/etc/passwd</b>.'' | ||
Le shell n'est pas seulement le prompt vous permettant de taper vos commandes, c'est aussi un puissant ''langage de commande'', vous permettant d'automatiser des tâches, etc. via l'écriture de ''scripts shell''. Apprendre le langage du shell peut être très enrichissant et utile ; néanmoins, cela dépasse le cadre de cette rubrique. Et puis je n'ai pas le courage de taper [http://abs.traduc.org/ une leçon sur bash] :) Par contre, vous trouverez ici les commandes de base, ainsi que les raccourcis clavier et les raccourcis du shell, les aliases, les variables d'environnement, la configuration du shell et j'en passe. C'est déjà pas mal non ? | Le shell n'est pas seulement le prompt vous permettant de taper vos commandes, c'est aussi un puissant ''langage de commande'', vous permettant d'automatiser des tâches, etc. via l'écriture de ''scripts shell''. Apprendre le langage du shell peut être très enrichissant et utile ; néanmoins, cela dépasse le cadre de cette rubrique. Et puis je n'ai pas le courage de taper [http://abs.traduc.org/ une leçon sur bash] :) Par contre, vous trouverez ici les commandes de base, ainsi que les raccourcis clavier et les raccourcis du shell, les aliases, les variables d'environnement, la configuration du shell et j'en passe. C'est déjà pas mal non ? | ||
Ligne 19 : | Ligne 22 : | ||
== Commandes pour débuter == | == Commandes pour débuter == | ||
Avant de commencer, il faut savoir que Linux est '''sensible à la casse''' (''case sensitive'' en anglais), c'est à dire qu'il distingue les majuscules des minuscules. Ainsi, si je vous dit que la commande est '< | Avant de commencer, il faut savoir que Linux est '''sensible à la casse''' (''case sensitive'' en anglais), c'est à dire qu'il distingue les majuscules des minuscules. Ainsi, si je vous dit que la commande est '<b>mkdir</b>', ce n'est pas la peine d'essayer <b>MKDIR</b> ou <b>mKdiR</b>, cela ne fonctionnera pas. De même, les noms de fichiers et de répertoires sont également sensibles à la casse. | ||
De plus, sous Unix, les chemins sont séparés par des slash : écrivez < | De plus, sous Unix, les chemins sont séparés par des slash : écrivez <b>/etc/rc.d/init.d/xfs</b> mais jamais <b>etc\rc.d\init.d\xfs</b> par pitié :) | ||
* '''Répertoires spéciaux''' : | * '''Répertoires spéciaux''' : | ||
< | <b>. </b> représente le répertoire courant, | ||
< | <b>.. </b> représente le répertoire parent | ||
< | <b>~ </b> représente le répertoire maison (home) de l'utilisateur | ||
* '''Fichiers cachés''' : | * '''Fichiers cachés''' : | ||
sous Unix, les fichiers cachés commencent par un point. Par exemple, ~/.bashrc est un fichier caché, dans le répertoire maison de l'utilisateur, qui contient la configuration de son shell. | sous Unix, les fichiers cachés commencent par un point. Par exemple, ~/.bashrc est un fichier caché, dans le répertoire maison de l'utilisateur, qui contient la configuration de son shell. | ||
* '''Jokers''' : ? et * | * '''Jokers''' : ? et * | ||
Les caractères < | Les caractères <b>?</b> et <b><nowiki>*</nowiki></b> dans les noms de fichiers et de répertoires permettent de représenter des caractères quelconques. '<b>?</b>' représente un seul caractère, tandis que '<b><nowiki>*</nowiki></b>' en représente un nombre quelconque. | ||
Par exemple "< | Par exemple "<b><nowiki>*.jpg</nowiki></b>" représente tous les fichiers se terminant par <b>jpg</b> ; "<b><nowiki>*toto*</nowiki></b>" tous les fichiers contenant "<b>toto</b>". Oui vous avez bien vu : on peut mettre plusieurs étoiles en même temps !!! Vous pouvez même faire : <b>cd /et*/rc.*/init*</b>, cela risque de fonctionner !!! | ||
Il faut également savoir que c'est le shell qui interprète ces caractères avant de transmettre la ligne de commande. Par exemple, si vous tapez : < | Il faut également savoir que c'est le shell qui interprète ces caractères avant de transmettre la ligne de commande. Par exemple, si vous tapez : <b>rm -Rf *.tmp</b>, le shell transformera cette ligne de commande en : <b>rm truc1.tmp truc2.tmp truc3.tmp</b>. | ||
* '''Jokers avancés''' : [] | * '''Jokers avancés''' : [] | ||
Vous pouvez aussi utiliser les crochets pour spécifier des caractères : | Vous pouvez aussi utiliser les crochets pour spécifier des caractères : | ||
< | <b>[a]</b> signifie : égal à 'a'. Exemple : <b>rm *[a]*</b> efface tous les fichiers contenant la lettre 'a'. | ||
< | <b>[!a]</b> signifie : différent de 'a'. Exemple : <b>rm *[!a]*</b> efface tous les fichiers, sauf ceux contenant la lettre 'a'. | ||
< | <b>[abc]</b> signifie : l'un des caractères a, b ou c. Exemple : <b>rm [abc]*.tmp</b> efface tous les fichiers commençant par a, b ou c. | ||
< | <b>[a-l]</b> : signifie : tous les caractères compris entre a et l. Exemple : <b>rm fic_[a-l]*</b> efface tous les fichiers commençant par <b>fic_</b> suivi d'une quelconque lettre entre a et l. | ||
''Bon c'est pas tout ça, voici les commandes de base sous Linux :'' | ''Bon c'est pas tout ça, voici les commandes de base sous Linux :'' | ||
Ligne 70 : | Ligne 73 : | ||
|- | |- | ||
| | | | ||
'''< | '''<b>cd</b>''' | ||
| | | | ||
'''< | '''<b>cd</b>''' | ||
| | | | ||
change le répertoire courant. | change le répertoire courant. | ||
| | | | ||
< | <b>cd ..</b><br /> - va dans le répertoire parent du répertoire courant | ||
< | <b>cd /home/user/.nsmail</b><br /> - va dans le répertoire désigné | ||
|- bgcolor="#CCCCCC" | |- bgcolor="#CCCCCC" | ||
| | | | ||
'''< | '''<b>ls</b>''' | ||
| | | | ||
'''< | '''<b>dir</b>''' | ||
| | | | ||
affiche le contenu d'un répertoire | affiche le contenu d'un répertoire | ||
| | | | ||
< | <b>ls</b><br /> - affiche le contenu du répertoire courant | ||
< | <b>ls -l</b><br /> - affiche le contenu du répertoire courant de manière détaillée | ||
< | <b>ls -a /home/user</b><br /> - affiche le contenu du répertoire désigné (ainsi que les fichiers cachés) | ||
|- | |- | ||
| | | | ||
'''< | '''<b>cp</b>''' | ||
| | | | ||
'''< | '''<b>copy</b>'''<br />'''<b>xcopy</b>''' | ||
| | | | ||
copie un ou plusieurs fichiers | copie un ou plusieurs fichiers | ||
| | | | ||
< | <b>cp toto /tmp</b><br /> - copie le fichier toto dans le répertoire <b>/tmp</b> | ||
< | <b>cp toto titi</b><br /> - copie le fichier <b>toto</b> sur le fichier <b>titi</b> | ||
< | <b>cp -R /home/user /tmp/bak</b><br /> - copie le répertoire <b>/home/user</b> ainsi que tout ce qu'il contient dans <b>/tmp/bak</b> | ||
|- bgcolor="#CCCCCC" | |- bgcolor="#CCCCCC" | ||
| | | | ||
'''< | '''<b>rm</b>''' | ||
| | | | ||
'''< | '''<b>del</b>''' | ||
| | | | ||
efface un ou plusieurs fichiers | efface un ou plusieurs fichiers | ||
| | | | ||
< | <b>rm toto titi</b><br /> - efface les fichiers <b>toto</b> et <b>titi</b> | ||
< | <b>rm -f toto titi</b><br /> - efface les fichiers <b>toto</b> et <b>titi</b> sans demander confirmation | ||
|- | |- | ||
| | | | ||
'''< | '''<b>rm -rf</b>''' | ||
| | | | ||
'''< | '''<b>deltree</b>''' | ||
| | | | ||
efface un répertoire et son contenu | efface un répertoire et son contenu | ||
| | | | ||
< | <b>rm -rf /tmp/*</b><br /> - efface (sans demander de confirmation) tous les fichiers et répertoires de <b>/tmp</b> | ||
|- bgcolor="#CCCCCC" | |- bgcolor="#CCCCCC" | ||
| | | | ||
'''< | '''<b>mkdir</b>''' | ||
| | | | ||
'''< | '''<b>md</b> ou <b>mkdir</b>''' | ||
| | | | ||
crée un répertoire | crée un répertoire | ||
| | | | ||
< | <b>mkdir /home/user/mes_documents</b><br /> - crée le répertoire <b>mes_documents</b> dans le sous répertoire <b>/home/user</b> (éviter de mettre des espaces dans les noms de fichiers ou de répertoires) | ||
|- | |- | ||
| | | | ||
'''< | '''<b>rmdir</b>''' | ||
| | | | ||
'''< | '''<b>rm</b>''' | ||
| | | | ||
efface un répertoire s'il est vide | efface un répertoire s'il est vide | ||
| | | | ||
< | <b>rmdir /home/user/.nsmail</b><br /> - efface le répertoire <b>.nsmail</b> de <b>/home/user</b> si celui-ci est vide | ||
|- bgcolor="#CCCCCC" | |- bgcolor="#CCCCCC" | ||
| | | | ||
'''< | '''<b>mv</b>''' | ||
| | | | ||
'''< | '''<b>ren</b>'''<br />'''<b>move</b>''' | ||
| | | | ||
déplace ou renomme un ou des fichiers | déplace ou renomme un ou des fichiers | ||
| | | | ||
< | <b>mv tata titi</b><br /> - renomme tata en titi | ||
< | <b>mv * *.bak</b><br /> - ne fonctionne pas !!!! | ||
< | <b>mv * /tmp/bak</b><br /> - déplace tous les fichiers du répertoire courant vers le répertoire <b>/tmp/bak</b> | ||
|- | |- | ||
| | | | ||
'''< | '''<b>find</b>''' | ||
| | | | ||
'''< | '''<b>dir -s</b>''' | ||
| | | | ||
trouve un fichier répondant à certains critères | trouve un fichier répondant à certains critères | ||
| | | | ||
< | <b>find /home -name "*bash*"</b><br /> - trouve tous les fichiers contenant le mot <b>bash</b> dans leur nom se trouvant dans le répertoire <b>/home</b> | ||
|- bgcolor="#CCCCCC" | |- bgcolor="#CCCCCC" | ||
| | | | ||
'''< | '''<b>locate</b>''' | ||
| | | | ||
'''< | '''<b>dir -s</b>''' | ||
| | | | ||
trouve un fichier d'après son nom | trouve un fichier d'après son nom | ||
| | | | ||
< | <b>locate bash</b><br /> - trouve tous les fichiers contenant le mot <b>bash</b> dans leur nom complet (avec le répertoire) : à la différence de <b>find</b>, locate trouve ses informations dans une base de donnée créée par <b>updatedb</b> | ||
|- | |- | ||
| | | | ||
'''< | '''<b>man</b>''' | ||
| | | | ||
'''< | '''<b>help</b>''' | ||
| | | | ||
affiche l'aide concernant une commande particulière | affiche l'aide concernant une commande particulière | ||
| | | | ||
< | <b>man ls</b><br /> - affiche l'aide (page de <b>man</b>uel) de la commnade <b>ls</b>. On quitte man en appuyant sur la touche '<b>q</b>' | ||
|- bgcolor="#CCCCCC" | |- bgcolor="#CCCCCC" | ||
| | | | ||
'''< | '''<b>chmod</b>''' | ||
| | | | ||
'''<b>cacls</b>''' | |||
| | | | ||
modifie les permissions d'un fichier | modifie les permissions d'un fichier | ||
| | | | ||
< | <b>chmod o+r /home/user</b><br /> - autorise les autres (<b>o=other</b>) (ie: ceux qui ne sont ni le propriétaire, ni membre du groupe propriétaire) à lire (<b>r=read</b>) le répertoire <b>/home/user</b> | ||
< | <b>chmod a+rw /home/user/unfichier</b><br /> - autorise tout le monde (<b>a=all</b>) à lire et écrire (<b>w=write</b>) dans le fichier <b>/home/user/unfichier</b> | ||
|- | |- | ||
| | | | ||
'''< | '''<b>chown</b>''' | ||
| | | | ||
pas <br /> d'équivalent | pas <br /> d'équivalent | ||
Ligne 202 : | Ligne 205 : | ||
modifie le propriétaire d'un fichier | modifie le propriétaire d'un fichier | ||
| | | | ||
< | <b>chown user unfichier</b><br /> rend <b>user</b> propriétaire de <b>unfichier</b>. | ||
|- bgcolor="#CCCCCC" | |- bgcolor="#CCCCCC" | ||
| | | | ||
'''< | '''<b>chgrp</b>''' | ||
| | | | ||
pas <br /> d'équivalent | pas <br /> d'équivalent | ||
Ligne 211 : | Ligne 214 : | ||
modifie le groupe proprétaire d'un fichier | modifie le groupe proprétaire d'un fichier | ||
| | | | ||
< | <b>chgrp -R nobody /home/httpd</b><br /> - rend le groupe : <b>nobody</b> (un groupe ayant très peu de droit sur un système linux) propriétaire de <b>/home/httpd</b> ainsi que tout les fichiers qu'il contient (<b>-R</b>) | ||
|- | |- | ||
| | | | ||
'''< | '''<b>ln -s</b>''' | ||
| | | | ||
pas <br /> d'équivalent | pas <br /> d'équivalent | ||
Ligne 220 : | Ligne 223 : | ||
crée un lien vers un fichier | crée un lien vers un fichier | ||
| | | | ||
< | <b>ln -s /dev/fd0 /dev/disquette</b><br /> crée un lien vers <b>/dev/fd0</b> (le lecteur de disquette) nommé <b>/dev/disquette</b>. La manipulation de <b>/dev/fd0</b> et <b>/dev/disquette</b> (sauf l'effacement). | ||
|- bgcolor="#CCCCCC" | |- bgcolor="#CCCCCC" | ||
| | | | ||
'''< | '''<b>grep</b>''' | ||
| | | | ||
pas <br /> d'équivalent | pas <br /> d'équivalent | ||
Ligne 229 : | Ligne 232 : | ||
recherche une chaine dans un fichier (en fait recherche une expression régulière dans plusieurs fichiers) | recherche une chaine dans un fichier (en fait recherche une expression régulière dans plusieurs fichiers) | ||
| | | | ||
< | <b>grep chaine *.txt</b><br /> - recherche la chaine '<b>chaine</b>' dans tous les fichier se terminant par <b>.txt</b>. | ||
|- | |- | ||
| | | | ||
'''< | '''<b>which</b>''' | ||
| | | | ||
pas <br /> d'équivalent | pas <br /> d'équivalent | ||
Ligne 238 : | Ligne 241 : | ||
trouve le répertoire dans lequel se trouve une commande | trouve le répertoire dans lequel se trouve une commande | ||
| | | | ||
< | <b>which emacs</b><br /> - retourne le nom du répertoire dans lequel se trouve la commande <b>emacs</b>. | ||
|- bgcolor="#CCCCCC" | |- bgcolor="#CCCCCC" | ||
| | | | ||
'''< | '''<b>cat</b>''' | ||
| | | | ||
'''< | '''<b>type</b>''' | ||
| | | | ||
affiche un fichier à l'écran | affiche un fichier à l'écran | ||
| | | | ||
< | <b>cat ~/.bashrc</b><br /> - affiche le contenu du fichier <b>~/.bashrc</b> | ||
|} | |} | ||
<u>Remarque</u> : <br /> Pour en savoir plus sur toutes ces commandes, je vous conseille de consulter leur page de man ! | <u>Remarque</u> : <br /> Pour en savoir plus sur toutes ces commandes, je vous conseille de consulter leur page de man ! | ||
=== La commande < | === La commande <b>ls</b> === | ||
Cette commande est omniprésente, aussi il est bon d'en présenter les basiques. | Cette commande est omniprésente, aussi il est bon d'en présenter les basiques. | ||
Afficher le listing page par page : < | Afficher le listing page par page : <b>ls | less</b> (<b>less</b> est une version améliorée de <b>more</b>) <br /> Afficher le listing en couleurs : <b>ls --color</b><br /> Afficher aussi les fichiers cachés (commençant par un point) : <b>ls -a</b><br /> Mettre un '/' après les noms de répertoires : <b>ls -p</b><br /> Afficher le listing détaillé : <b>ls -l</b> | ||
<u>Tri sur la date</u><br /> Pour afficher les fichiers d'un répertoire en triant sur la date de mise à jour des fichiers <br /> Afficher les fichiers les plus récents en premier : < | <u>Tri sur la date</u><br /> Pour afficher les fichiers d'un répertoire en triant sur la date de mise à jour des fichiers <br /> Afficher les fichiers les plus récents en premier : <b>ls -t</b><br /> Afficher les fichiers les plus vieux en premier : <b>ls -rt</b><br /> Mixer avec l'option "l" afin d'afficher le listing détaillé : <b>ls -rtl</b> ou <b>ls -tl</b> | ||
''bien sûr, toutes ces options sont mixables,'' ainsi "< | ''bien sûr, toutes ces options sont mixables,'' ainsi "<b>ls -altp</b>" affiche tous les fichiers, de façon détaillée, dans l'ordre chronologique, an ajoutant '/' après chaque nom de répertoire. | ||
<u>Exemple de listing</u> | <u>Exemple de listing</u> | ||
Ligne 268 : | Ligne 271 : | ||
<u>Explication :</u><br /> La première ligne "total 144" est l'espace disque utilisé par l'ensemble des fichiers du répertoire. | <u>Explication :</u><br /> La première ligne "total 144" est l'espace disque utilisé par l'ensemble des fichiers du répertoire. | ||
# La première colonne < | # La première colonne <b>-rw-r--r--</b>représente les '''permissions''' associées au fichier. le premier caractère est un tiret pour un fichier, un d pour un répertoire, un l pour un lien, etc. <br /> ensuite, on a trois groupes de trois caractères : <b>rw-</b> ou <b>r--</b> ou <b>rwx</b> ou... <br /> Le premier groupe représente les permissions associées à l'utilisateur (ici, jice), le deuxième celles associées à son groupe (ici : users), enfin le dernier est les permissions que tout le monde a sur ces fichiers. <br /><b>r</b> signifie : possibilité de lire ce fichier / dans ce répertoire, <br /><b>w</b> signifie : possibilité d'écrire dans ce fichier / répertoire, <br /><b>x</b> signifie : possibilité d'exécuter ce fichier / d'aller dans ce répertoire. | ||
# nombre d'inodes (partie élémentaire de [../docs/glossaire.php3#systeme_fichiers système de fichiers]) qui pointent vers le fichier/répertoire (généralement 1 pour un fichier, 2+le nombre de sous-répertoires pour un répertoire). | # nombre d'inodes (partie élémentaire de [../docs/glossaire.php3#systeme_fichiers système de fichiers]) qui pointent vers le fichier/répertoire (généralement 1 pour un fichier, 2+le nombre de sous-répertoires pour un répertoire). | ||
# utilisateur à qui appartient le fichier (jice) | # utilisateur à qui appartient le fichier (jice) | ||
Ligne 288 : | Ligne 291 : | ||
'''Quelle commande utiliser pour faire ... ceci ou cela ?''' | '''Quelle commande utiliser pour faire ... ceci ou cela ?''' | ||
| | | | ||
< | <b>apropos mot_clef</b> ou <b>man -k mot_clef</b><br /> - affiche les commandes, brièvement définies, en rapport avec mot_clef. <br /><b>apropos copier</b><br /> - affiche les commandes en rapport avec la copie d'un fichier, d'une chaîne, d'une zone mémoire ... <br /><b>apropos permission</b><br /> - affiche les commandes liées à la vérification et à la modification des permissions. | ||
Notes : les noms communs et les verbes à l'infinitif permettent généralement de trouver facilement la commande recherchée. En cas d'échec, pensez aux synonymes : apropos supprimer fait apparaître la commande rmdir (supprimer un répertoire), alors que apropos effacer fait apparaître la commande rm (effacer un fichier). | Notes : les noms communs et les verbes à l'infinitif permettent généralement de trouver facilement la commande recherchée. En cas d'échec, pensez aux synonymes : apropos supprimer fait apparaître la commande rmdir (supprimer un répertoire), alors que apropos effacer fait apparaître la commande rm (effacer un fichier). | ||
Ligne 295 : | Ligne 298 : | ||
'''Comment se définit cette commande ?''' | '''Comment se définit cette commande ?''' | ||
| | | | ||
< | <b>whatis nom_commande</b> ou <b>man -f nom_commande</b><br /> - affiche une brève définition de nom_commande. <br /><b>whatis whatis</b><br /> - affiche la définition de whatis. <br /><b>whatis arch</b><br /> - affiche la définition de la commande arch. <br /><b>cd /bin ; for i in * ; do whatis $i ; done | more ; cd</b><br /> - se positionne dans le répertoire /bin/, affiche page par page la définition de chacune des commandes qui s'y trouve, retourne au répertoire personnel. | ||
Notes : dans l'exemple précédant vous pouvez bien sûr remplacer /bin par /sbin ; certaines entrées échouent. | Notes : dans l'exemple précédant vous pouvez bien sûr remplacer /bin par /sbin ; certaines entrées échouent. | ||
Ligne 302 : | Ligne 305 : | ||
'''Quelles sont et comment utiliser les commandes internes ?''' | '''Quelles sont et comment utiliser les commandes internes ?''' | ||
| | | | ||
< | <b>help</b><br /> - affiche la liste des commandes internes et leur syntaxe. <br /><b>help nom_commande</b><br /> - affiche une aide sommaire sur nom_commande. <br /><b>help help</b><br /> - affiche une aide sur help. <br /><b>help alias</b><br /> - affiche une aide sur la commande alias. | ||
Notes : ces commandes sont les commandes internes du shell, généralement le bash. Vous pouvez aussi en obtenir la liste en demandant à propos de l'une d'elles une page man qui n'existe pas (man :). Vous trouverez également une aide sur les commandes internes dans la page man de bash (man bash). Enfin notez que help concerne les commandes internes mais --help les commandes externes. | Notes : ces commandes sont les commandes internes du shell, généralement le bash. Vous pouvez aussi en obtenir la liste en demandant à propos de l'une d'elles une page man qui n'existe pas (man :). Vous trouverez également une aide sur les commandes internes dans la page man de bash (man bash). Enfin notez que help concerne les commandes internes mais --help les commandes externes. | ||
Ligne 309 : | Ligne 312 : | ||
<br />'''Où sont et quelles sont les commandes externes ?''' | <br />'''Où sont et quelles sont les commandes externes ?''' | ||
| | | | ||
< | <b>ls /bin</b><br /> - affiche le contenu du répertoire /bin/, et donc la liste des commandes externes usuelles communes à tous les utilisateurs. <br /><b>ls /sbin</b><br /> - affiche le contenu du répertoire /sbin/, et donc la liste des commandes externes usuelles réservées à l'administrateur (root). <br /><b>whereis nom_commande</b><br /> - affiche le chemin de nom_commande ainsi que celui de sa page man. <br /><b>whereis cat</b><br /> - affiche le chemin de la commande cat (/bin/cat) et celui de sa page man (/usr/share/man/man1/cat.1.bz2). <br /><b>which nom_commande</b><br /> - affiche le chemin de nom_commande. <br /><b>which tac</b><br /> - affiche le chemin de tac (/usr/bin/tac). | ||
Notes : les répertoires /usr/bin/ et /usr/sbin/ contiennent les commandes externes moins fréquemment utilisées. Pour savoir si une commande est externe vous pouvez aussi simplement vérifier qu'elle n'est pas interne ! | Notes : les répertoires /usr/bin/ et /usr/sbin/ contiennent les commandes externes moins fréquemment utilisées. Pour savoir si une commande est externe vous pouvez aussi simplement vérifier qu'elle n'est pas interne ! | ||
Ligne 316 : | Ligne 319 : | ||
'''Comment obtenir un aide mémoire sur cette commande ?''' | '''Comment obtenir un aide mémoire sur cette commande ?''' | ||
| | | | ||
< | <b>nom_commande --help</b><br /> - affiche l'aide mémoire de nom commande. <br /><b>ls --help</b><br /> - affiche l'aide mémoire de la commande ls. | ||
Notes : --help concerne la plupart des commandes externes et help les commandes internes. echo --help affiche bien sûr ... --help. | Notes : --help concerne la plupart des commandes externes et help les commandes internes. echo --help affiche bien sûr ... --help. | ||
Ligne 323 : | Ligne 326 : | ||
'''La dernière commande s'est-elle bien terminée ?''' | '''La dernière commande s'est-elle bien terminée ?''' | ||
| | | | ||
< | <b>echo $?</b><br /> - affiche le code de retour de la dernière commande effectuée, 0 si elle s'est bien terminée, un autre nombre dans le cas contraire. <br /><b>clear ; echo $?</b><br /> - efface l'écran et affiche 0. <br /><b>sl / ; echo $?</b><br /> - affiche un message d'erreur et le code 127 (bash ne connaît pas la commande sl). <br /><b>nom_commande 2>/dev/null && echo "ok" || echo "m'enfin"</b><br /> - exécute nom_commande en redirigeant les erreurs vers /dev/null (périphérique fictif) puis affiche "ok" si tout s'est bien passé ou "m'enfin" dans le cas contraire. <br /><b><nowiki>: && echo "ok" || echo "m'enfin"</nowiki></b><br /> - ne fait rien puis affiche "ok" (la commande : ne fait rien et se termine toujours bien). <br /><b>bof 2>/dev/null && echo "ok" || echo "m'enfin"</b><br /> - affiche "m'enfin" (la commande bof n'existe pas). | ||
Notes : commande1 && commande2 exécute commande2 que si commande1 s'est terminée normalement (0) ; commande1 || commande2 exécute commande2 que si commande1 ne s'est pas terminée correctement (<>0). | Notes : commande1 && commande2 exécute commande2 que si commande1 s'est terminée normalement (0) ; commande1 || commande2 exécute commande2 que si commande1 ne s'est pas terminée correctement (<>0). | ||
Ligne 330 : | Ligne 333 : | ||
'''Quels sont le nom, la taille et le contenu du fichier d'historique ?''' | '''Quels sont le nom, la taille et le contenu du fichier d'historique ?''' | ||
| | | | ||
< | <b>echo $HISTFILE $HISTFILESIZE</b><br /> - affiche le nom et la taille du fichier d'historique des commandes. <br /><b>cat $HISTFILE | more</b><br /> - affiche le contenu du fichier d'historique page par page. <br /><b>tail -n 24 $HISTFILE</b><br /> - affiche les 24 dernières lignes du fichier d'historique. | ||
Notes : le fichier d'historique vous aide à répondre à la question : mais comment j'avais fait ? et à en conserver une trace d'une connexion à l'autre. | Notes : le fichier d'historique vous aide à répondre à la question : mais comment j'avais fait ? et à en conserver une trace d'une connexion à l'autre. | ||
Ligne 337 : | Ligne 340 : | ||
'''Quel est l'historique actuel ?''' | '''Quel est l'historique actuel ?''' | ||
| | | | ||
< | <b>history | more</b><br /> - affiche page par page le contenu numéroté de l'historique actuel des commandes. <br /><b>history 12</b><br /> - affiche les 12 dernières entrées effectuées et leurs numéros. | ||
Notes : c'est cet historique qui défile avec les touches "flèches" de votre clavier ; au démarrage, c'est le contenu de votre fichier d'historique. | Notes : c'est cet historique qui défile avec les touches "flèches" de votre clavier ; au démarrage, c'est le contenu de votre fichier d'historique. | ||
Ligne 348 : | Ligne 351 : | ||
'''Quel est le système ?''' | '''Quel est le système ?''' | ||
| | | | ||
< | <b>uname</b> ou <b>echo $OSTYPE</b><br /> - affiche le nom du système d'exploitation. <br /><b>uname -a</b><br /> - affiche diverses informations système (nom du SE, version, microprocesseur ...). <br /><b>arch</b> ou <b>uname -m</b><br /> - affiche le type du microprocesseur. <br /><b>cat /proc/cpuinfo</b><br /> - affiche des informations sur le microprocesseur (type, fréquence, cache ...). | ||
Notes : les informations recueillies avec uname -a peuvent aussi être obtenues avec certaines variables système : echo $OSTYPE $BASH $BASH_VERSION etc. | Notes : les informations recueillies avec uname -a peuvent aussi être obtenues avec certaines variables système : echo $OSTYPE $BASH $BASH_VERSION etc. | ||
Ligne 355 : | Ligne 358 : | ||
'''Depuis combien de temps ce shell est-il actif ?''' | '''Depuis combien de temps ce shell est-il actif ?''' | ||
| | | | ||
< | <b>uptime</b><br /> - affiche l'heure, la durée d'activité du système, le nombre d'utilisateurs ... <br /><b>echo $SECONDS</b><br /> - affiche la durée d'activité du shell courant en secondes. <br /> echo $[$SECONDS/3600] h $[($SECONDS%3600)/60] mn $[$SECONDS%60] s <br /> - affiche cette durée en heures, minutes et secondes. | ||
Notes : bash ne connaît que les entiers et donc que les divisions euclidiennes, / permet d'en obtenir le quotient et % d'en obtenir le reste (ou modulo). Chaque fois que vous changez de terminal, ouvrez un nouvel xterm ou faites un su, celui-ci correspond à un nouveau (sous)shell, sa variable SECONDS est donc alors à 0. Pour savoir depuis combien de temps vous êtes sous Linux, revenez à votre console de login ; pour savoir depuis quand le système est actif, utilisez uptime. | Notes : bash ne connaît que les entiers et donc que les divisions euclidiennes, / permet d'en obtenir le quotient et % d'en obtenir le reste (ou modulo). Chaque fois que vous changez de terminal, ouvrez un nouvel xterm ou faites un su, celui-ci correspond à un nouveau (sous)shell, sa variable SECONDS est donc alors à 0. Pour savoir depuis combien de temps vous êtes sous Linux, revenez à votre console de login ; pour savoir depuis quand le système est actif, utilisez uptime. | ||
Ligne 362 : | Ligne 365 : | ||
'''Qu'en est-il des disques, de la mémoire, du microprocesseur ?''' | '''Qu'en est-il des disques, de la mémoire, du microprocesseur ?''' | ||
| | | | ||
< | <b>mount</b><br /> - affiche la liste des disques montés. <br /><b>df -ah</b><br /> - affiche au format humain l'espace total, occupé, libre sur tous les disques. <br /><b>free</b> ou <b>cat /proc/meminfo</b><br /> - affiche des informations sur la mémoire (totale, libre, swap ...). <br /><b>vmstat</b><br /> - affiche les statistiques sur la mémoire virtuelle. <br /><b>top</b><br /> - affiche et permet d'observer en temps réel l'activité de la mémoire et du microprocesseur. | ||
Notes : la touche <Q> permet de quitter la commande top. | Notes : la touche <Q> permet de quitter la commande top. | ||
Ligne 369 : | Ligne 372 : | ||
'''Quelles sont et que signifient les variables système ?''' | '''Quelles sont et que signifient les variables système ?''' | ||
| | | | ||
< | <b>$<Tab></b><br /> - affiche les noms des principales variables système. <br /><b>help variables | more</b><br /> - affiche page par page la définition des principales variables système. | ||
Notes : les noms des variables système sont généralement écrits en majuscules. A chacune de ces variables correspond une question et une réponse, quelques unes seulement ont été formulées à divers endroits dans cette page. | Notes : les noms des variables système sont généralement écrits en majuscules. A chacune de ces variables correspond une question et une réponse, quelques unes seulement ont été formulées à divers endroits dans cette page. | ||
Ligne 376 : | Ligne 379 : | ||
'''Que contiennent ces variables système ?''' | '''Que contiennent ces variables système ?''' | ||
| | | | ||
< | <b>echo $NOM_VARIABLE</b><br /> - affiche le contenu de NOM_VARIABLE. <br /><b>echo $USER</b><br /> - affiche le nom de l'utilisateur en cours. <br /><b>echo $PS1</b><br /> - affiche la chaîne de caractères définissant le prompt. <br /><b>printenv | more</b><br /> - affiche page par page l'environnement. <br /><b>set | more</b><br /> - affiche page par page le contenu des principales variables système. | ||
Notes : vous pouvez bien sûr modifier le prompt PS1="chaîne de caractères". Pour rendre cette modification générale et durable, il faut utiliser le fichier /etc/bashrc (nécessite d'être root). | Notes : vous pouvez bien sûr modifier le prompt PS1="chaîne de caractères". Pour rendre cette modification générale et durable, il faut utiliser le fichier /etc/bashrc (nécessite d'être root). | ||
Ligne 383 : | Ligne 386 : | ||
'''Qui suis-je et qui est ou était connecté au système ?''' | '''Qui suis-je et qui est ou était connecté au système ?''' | ||
| | | | ||
< | <b>id nom_utilisateur</b><br /> - affiche les identifications de nom_utilisateur. <br /><b>id</b><br /> - affiche vos identifications : UID, GDI, groupes. <br /><b>who am i</b><br /> - affiche vos coordonnées dans le système. <br /><b>who -H</b><br /> - affiche avec une entête des informations (nom de login, console ... ) sur les utilisateurs connectés. <br /><b>w </b><br /> - affiche qui est connecté (who -H) et aussi ce qu'il fait. <br /><b>last -n 12</b><br /> - affiche la liste des 12 dernières connexions. | ||
Notes : la commande who am i ne fonctionne pas toujours sous xterm, dans ce cas entrez whoami mais vous n'obtiendrez que votre nom de login. De nombreuses commandes permettent d'obtenir une partie des renseignements évoqués ci-dessus, leurs noms parlent d'eux-mêmes : logname, users, groups ... | Notes : la commande who am i ne fonctionne pas toujours sous xterm, dans ce cas entrez whoami mais vous n'obtiendrez que votre nom de login. De nombreuses commandes permettent d'obtenir une partie des renseignements évoqués ci-dessus, leurs noms parlent d'eux-mêmes : logname, users, groups ... | ||
Ligne 390 : | Ligne 393 : | ||
'''Quelles sont la date et l'heure ?''' | '''Quelles sont la date et l'heure ?''' | ||
| | | | ||
< | <b>date</b><br /> - affiche la date et l'heure. br /><b>date +%x</b><br /> - affiche seulement la date au format jj.mm.aaaa. <br /><b>date +%X</b><br /> - affiche uniquement l'heure au format hh:mm:ss. <br /><b>cal</b><br /> - affiche un calendrier du mois en cours. <br /><b>cal 2000</b><br /> - affiche le calendrier de l'an 2000, etc. | ||
|- | |- | ||
| | | | ||
'''Y a-t-il un manchot dans le système ?''' | '''Y a-t-il un manchot dans le système ?''' | ||
| | | | ||
< | <b>linux_logo</b><br /> - affiche Tux et diverses informations système. <br /><b>linux_logo -la</b><br /> - affiche Tux en ASCII et sans informations :-) | ||
Notes : sur mon système, linux_logo -la produit bien l'affichage attendu (-a = ASCII et -l = pas d'informations) mais avec linux_logo -al, l'option -l est ignorée et les informations sont affichées ... Y a-t-il un bug dans mon système ? | Notes : sur mon système, linux_logo -la produit bien l'affichage attendu (-a = ASCII et -l = pas d'informations) mais avec linux_logo -al, l'option -l est ignorée et les informations sont affichées ... Y a-t-il un bug dans mon système ? | ||
Ligne 406 : | Ligne 409 : | ||
'''Quel est le répertoire courant ?''' | '''Quel est le répertoire courant ?''' | ||
| | | | ||
< | <b>pwd</b><br /> - affiche le nom complet du répertoire en cours. | ||
|- | |- | ||
| | | | ||
'''Quelle est la taille de ce répertoire ?''' | '''Quelle est la taille de ce répertoire ?''' | ||
| | | | ||
< | <b>du -sh </b><br /> - affiche au format humain la taille du répertoire courant. <br /><b>du -h ~ | more</b><br /> - affiche page par page au format humain la taille de votre répertoire personnel et de tous ses (sous)répertoires. | ||
Notes : du ne fonctionne que sur les répertoires où vous avez droit d'accès, si nécessaire passez sous root. | Notes : du ne fonctionne que sur les répertoires où vous avez droit d'accès, si nécessaire passez sous root. | ||
Ligne 418 : | Ligne 421 : | ||
'''Quel est le type de ce fichier ?''' | '''Quel est le type de ce fichier ?''' | ||
| | | | ||
< | <b>file nom_fichier</b><br /> - affiche le type de nom_fichier. <br /><b>file *</b><br /> - affiche le type de tous les fichiers du répertoire en cours. <br /><b>file /bin</b><br /> - affiche que /bin/ est un répertoire. <br /><b>file /bin/sh</b><br /> - affiche que sh est un lien symbolique vers bash. <br /><b>file /bin/bash</b><br /> - affiche que bash est un exécutable. <br /><b>file ~/.bashrc</b><br /> - affiche que .bashrc de votre répertoire personnel est un fichier texte. <br /><b>file /dev/null</b><br /> - affiche que null est un fichier spécial. | ||
Notes : file sait reconnaître un grand nombre de types de fichiers parmi les fichiers spéciaux, exécutables, textes, données ... Il est préférable de l'utiliser avant d'entrer un "cat" au hasard. | Notes : file sait reconnaître un grand nombre de types de fichiers parmi les fichiers spéciaux, exécutables, textes, données ... Il est préférable de l'utiliser avant d'entrer un "cat" au hasard. | ||
Ligne 436 : | Ligne 439 : | ||
<div class="code">'''[user@localhost user]$''' cd /usr/doc/H'''[Tab][Tab]'''<br /> HTML HOWTO<br />'''[user@localhost user]$''' cd /usr/doc/H_</div> | <div class="code">'''[user@localhost user]$''' cd /usr/doc/H'''[Tab][Tab]'''<br /> HTML HOWTO<br />'''[user@localhost user]$''' cd /usr/doc/H_</div> | ||
* '''Flèche vers le haut (ou Ctrl-P) / bas (ou Ctrl-N)''' | * '''Flèche vers le haut (ou Ctrl-P) / bas (ou Ctrl-N)''' | ||
La flèche vers le haut permet de remonter dans l'historique des commandes, la flèche vers le bas permet de revenir. Vous pouvez aussi utiliser la commande < | La flèche vers le haut permet de remonter dans l'historique des commandes, la flèche vers le bas permet de revenir. Vous pouvez aussi utiliser la commande <b>fc</b>, consultez <b>man fc</b>. | ||
* '''Shift - flèche vers le haut/bas''' | * '''Shift - flèche vers le haut/bas''' | ||
Permet de scroller le contenu du terminal texte vers le haut ou le bas, d'une ligne. En effet, les lignes qui ont défilé vers le haut restent en mémoire et restent accessibles. Terrible, non ? | Permet de scroller le contenu du terminal texte vers le haut ou le bas, d'une ligne. En effet, les lignes qui ont défilé vers le haut restent en mémoire et restent accessibles. Terrible, non ? | ||
Ligne 444 : | Ligne 447 : | ||
Arrête le processus en cours, celui qui a été lancé par la dernière commande. | Arrête le processus en cours, celui qui a été lancé par la dernière commande. | ||
* '''Ctrl-Z''' | * '''Ctrl-Z''' | ||
Stoppe le processus en cours, celui qui a été lancé par la dernière commande, mais ne le détruit pas : il reste en attente. Pour le mettre en tâche de fond (il continue à s'exécuter, mais vous pouvez continuer à taper des commandes), tapez '''< | Stoppe le processus en cours, celui qui a été lancé par la dernière commande, mais ne le détruit pas : il reste en attente. Pour le mettre en tâche de fond (il continue à s'exécuter, mais vous pouvez continuer à taper des commandes), tapez '''<b>bg</b>'''. Pour le faire revenir en avant, taper '''<b>fg</b>'''. | ||
* '''Ctrl-D''' | * '''Ctrl-D''' | ||
Ferme le terminal en cours (similaire à < | Ferme le terminal en cours (similaire à <b>exit</b> ou <b>logout</b>). | ||
et aussi... | et aussi... | ||
Ligne 453 : | Ligne 456 : | ||
Se place sur la console virtuelle numéro '''n'''. Par défaut, il y a en général 6 consoles texte virtuelles, de F1 à F6, et X Window se lance dans la septième (F7). | Se place sur la console virtuelle numéro '''n'''. Par défaut, il y a en général 6 consoles texte virtuelles, de F1 à F6, et X Window se lance dans la septième (F7). | ||
* '''Ctrl-Alt-Backspace''' | * '''Ctrl-Alt-Backspace''' | ||
Cela permet de tuer X et de revenir soit à la [../docs/glossaire.php3#display_manager bannière de login] soit au shell qui a lancé X par < | Cela permet de tuer X et de revenir soit à la [../docs/glossaire.php3#display_manager bannière de login] soit au shell qui a lancé X par <b>startx</b>. A éviter si possible : il est plus sain de quitter X en se déconnectant proprement. | ||
* '''Ctrl-Alt-Del''' | * '''Ctrl-Alt-Del''' | ||
Suivant votre configuration, ces touches à l'action bien connue vous permettrons de rebooter votre ordinateur (synonyme de < | Suivant votre configuration, ces touches à l'action bien connue vous permettrons de rebooter votre ordinateur (synonyme de <b>reboot</b> ou <b>shutdown -r now</b>). Si vous souhaitez juste arrêter votre ordinateur afin de l'éteindre, tapez <b>halt</b>, ou <b>shutdown -h now</b>. | ||
=== Shell === | === Shell === | ||
Ligne 461 : | Ligne 464 : | ||
Les shells Unix disposent de petits "raccourcis" très astucieux et utiles, qui vous épargnerons de taper sur quelques touches. Ne dit-on pas qu'un bon informaticien est un informaticien fainéant ? :-) | Les shells Unix disposent de petits "raccourcis" très astucieux et utiles, qui vous épargnerons de taper sur quelques touches. Ne dit-on pas qu'un bon informaticien est un informaticien fainéant ? :-) | ||
'''Dernière ligne de commande : < | '''Dernière ligne de commande : <b>!!</b>''' | ||
On a vu plus haut qu'elle était accessible par la flèche vers le haut, mais vous pouvez également la désigner par '< | On a vu plus haut qu'elle était accessible par la flèche vers le haut, mais vous pouvez également la désigner par '<b>!!</b>', ce qui peut être très intéressant. | ||
<div class="code">'''[user@localhost user]$''' vi<br />'''[user@localhost user]$''' which !!<br /> which vi<br /> /bin/vi</div> | <div class="code">'''[user@localhost user]$''' vi<br />'''[user@localhost user]$''' which !!<br /> which vi<br /> /bin/vi</div> | ||
'''Arguments de la dernière commande : < | '''Arguments de la dernière commande : <b>!*</b>''' | ||
Les arguments de la dernière commande peuvent être représentés par '< | Les arguments de la dernière commande peuvent être représentés par '<b>!*</b>'. | ||
<div class="code">'''[user@localhost user]$''' mkdir test<br />'''[user@localhost user]$''' cd !<br /> cd test</div> | <div class="code">'''[user@localhost user]$''' mkdir test<br />'''[user@localhost user]$''' cd !<br /> cd test</div> | ||
Ligne 475 : | Ligne 478 : | ||
'''Utiliser la sortie d'une commande comme argument :''' | '''Utiliser la sortie d'une commande comme argument :''' | ||
Vous pouvez réutiliser directement ce qu'une commande écrit à l'écran comme argument pour une autre commande. Pour ce faire, vous devez encadrer la commande par une cote inverse < | Vous pouvez réutiliser directement ce qu'une commande écrit à l'écran comme argument pour une autre commande. Pour ce faire, vous devez encadrer la commande par une cote inverse <b>`</b> ou la mettre entre parenthèses précédées du signe $ ; elle sera remplacée par ce qu'elle écrit à l'écran dans la ligne de commande. Imaginez par exemple que vous vouliez voir les informations sur le fichier exécutable de emacs. | ||
<div class="code">'''[user@localhost user]$''' ls -l `which emacs`<br />'''[user@localhost user]$''' ls -l $(which emacs)</div> | <div class="code">'''[user@localhost user]$''' ls -l `which emacs`<br />'''[user@localhost user]$''' ls -l $(which emacs)</div> | ||
Ligne 489 : | Ligne 492 : | ||
C'est-y pas beau ça madame ? | C'est-y pas beau ça madame ? | ||
'''Remplacer un caractère par un autre : < | '''Remplacer un caractère par un autre : <b>^</b>''' | ||
Si vous souhaitez remplacer la première occurrence d'un caractère de la ligne de commande précédente par un autre, vous pouvez utiliser le symbole < | Si vous souhaitez remplacer la première occurrence d'un caractère de la ligne de commande précédente par un autre, vous pouvez utiliser le symbole <b>^</b>, comme ci-dessous : | ||
<div class="code">'''[user@localhost user]$''' lpcate i486-linux-libc5<br /> lpcate : command not found<br />'''[user@localhost user]$''' ^p^o<br /> locate i486-linux-libc5</div> | <div class="code">'''[user@localhost user]$''' lpcate i486-linux-libc5<br /> lpcate : command not found<br />'''[user@localhost user]$''' ^p^o<br /> locate i486-linux-libc5</div> | ||
< | <b>^p^o</b> signifie : refait la même ligne de commande que précédemment, mais remplace le premier p par un o. | ||
'''Lancer un programme directement en tâche de fond : &''' | '''Lancer un programme directement en tâche de fond : &''' | ||
Il suffit de faire suivre la ligne de commande du symbole < | Il suffit de faire suivre la ligne de commande du symbole <b>&</b> : | ||
<div class="code">'''[user@localhost user]$''' cp -R /usr/doc /tmp &<br /> [1] 7194<br />'''[user@localhost user]$''' _</div> | <div class="code">'''[user@localhost user]$''' cp -R /usr/doc /tmp &<br /> [1] 7194<br />'''[user@localhost user]$''' _</div> | ||
Ligne 507 : | Ligne 510 : | ||
<div class="code">'''[user@localhost user]$'''<br /> [1]+ Done cp -R /usr/doc /tmp<br />'''[user@localhost user]$''' _ </div> | <div class="code">'''[user@localhost user]$'''<br /> [1]+ Done cp -R /usr/doc /tmp<br />'''[user@localhost user]$''' _ </div> | ||
'''Lancer plusieurs programmes en même temps : &, &&, < | '''Lancer plusieurs programmes en même temps : &, &&, <b>||</b>, <b><nowiki>;</nowiki></b>''' | ||
Vous avez plusieurs solutions : | Vous avez plusieurs solutions : | ||
< | <b>prog1 ; prog2 </b> lance prog1, puis prog2, | ||
< | <b>prog1 & prog2 </b> lance prog1 en arrière plan, puis immédiatement prog2 en avant plan, | ||
< | <b>prog1 && prog2</b> lance prog1, puis prog2 seulement si prog1 n'a pas retourné d'erreur, | ||
< | <b>prog1 || prog2</b> lance prog1, puis prog2 seulement si prog1 A retourné une erreur. | ||
---- | ---- | ||
Ligne 523 : | Ligne 526 : | ||
== Redirections == | == Redirections == | ||
Normalement, la sortie des programmes se fait à l'écran, aussi bien pour les erreurs (''standard error'') que pour les messages "normaux" (''standard output''). Vous pouvez la rediriger, soit vers un fichier avec < | Normalement, la sortie des programmes se fait à l'écran, aussi bien pour les erreurs (''standard error'') que pour les messages "normaux" (''standard output''). Vous pouvez la rediriger, soit vers un fichier avec <b>></b>, soit vers l'entrée d'un autre programme avec <b>|</b> (ou pipe - attention, arrêtez de rigoler dans le fond :-). | ||
De même, l'entrée standard (''standard input'') est habituellement constituée du clavier, mais on peut aussi la remplacer par le contenu d'un fichier, avec le symbole < | De même, l'entrée standard (''standard input'') est habituellement constituée du clavier, mais on peut aussi la remplacer par le contenu d'un fichier, avec le symbole <b><</b>. | ||
=== Envoyer la sortie standard d'un programme dans l'entrée standard d'un autre === | === Envoyer la sortie standard d'un programme dans l'entrée standard d'un autre === | ||
Ligne 533 : | Ligne 536 : | ||
<div class="code">'''[user@localhost user]$''' ls -la '''<font size="+1">|</font>''' more</div> | <div class="code">'''[user@localhost user]$''' ls -la '''<font size="+1">|</font>''' more</div> | ||
< | <b>ls -la</b> envoie la version longue du listing de répertoire, avec les fichier cachés, à <b>more</b> qui l'affiche page par page. <br /> Vous pouvez aussi enchaîner plusieurs redirections : | ||
<div class="code">'''[user@localhost user]$''' cat /var/log/messages '''|''' grep gpm '''|''' more</div> | <div class="code">'''[user@localhost user]$''' cat /var/log/messages '''|''' grep gpm '''|''' more</div> | ||
Ceci va afficher page par page l'ensemble des messages système relatifs à < | Ceci va afficher page par page l'ensemble des messages système relatifs à <b>gpm</b>. (voir plus haut ce que font chacune de ces commandes). | ||
=== Envoi d'un fichier dans l'entrée standard === | === Envoi d'un fichier dans l'entrée standard === | ||
Ligne 545 : | Ligne 548 : | ||
<div class="code">'''[user@localhost user]$''' ftp < sessiontype.txt </div> | <div class="code">'''[user@localhost user]$''' ftp < sessiontype.txt </div> | ||
Ici le fichier < | Ici le fichier <b>sessiontype.txt</b> pourra contenir par exemple : | ||
<div class="code"> open ftp.lesite.com<br /> user jice<br /> pass xxxxxx<br /> cd /pub/linux/doc<br /> bin<br /> get jice.jpg<br /> bye</div> | <div class="code"> open ftp.lesite.com<br /> user jice<br /> pass xxxxxx<br /> cd /pub/linux/doc<br /> bin<br /> get jice.jpg<br /> bye</div> | ||
Et vous permettra en une seule commande de récupérer le fichier < | Et vous permettra en une seule commande de récupérer le fichier <b>jice.jpg</b> sur le site <b>ftp.lesite.com</b> (utile si ce fichier change et que vous voulez le mettre à jour régulièrement). Bref, à vous d'inventer la vie qui va avec :-) | ||
=== Redirection des sorties vers un fichier === | === Redirection des sorties vers un fichier === | ||
Ligne 555 : | Ligne 558 : | ||
<div class="code">'''[user@localhost user]$''' ls -lR /cdrom '''<font size="+1">></font>''' cdrom.txt</div> | <div class="code">'''[user@localhost user]$''' ls -lR /cdrom '''<font size="+1">></font>''' cdrom.txt</div> | ||
Cette commande va lister le contenu du cdrom, et enregistrer le résultat dans le fichier < | Cette commande va lister le contenu du cdrom, et enregistrer le résultat dans le fichier <b>cdrom.txt</b>. <br /> En mettant deux <b>></b> de suite, vous ajoutez au fichier : | ||
<div class="code">'''[user@localhost user]$''' date '''<font size="+1">>></font>''' cdrom.txt</div> | <div class="code">'''[user@localhost user]$''' date '''<font size="+1">>></font>''' cdrom.txt</div> | ||
Ligne 561 : | Ligne 564 : | ||
Ceci va ajouter la date au fichier précédemment créé. | Ceci va ajouter la date au fichier précédemment créé. | ||
Les messages d'erreur peuvent être dirigés séparément dans un fichier avec '''< | Les messages d'erreur peuvent être dirigés séparément dans un fichier avec '''<b>2></b>''' : | ||
<div class="code">'''[user@localhost user]$''' startx > startx.log '''2>''' startx.err</div> | <div class="code">'''[user@localhost user]$''' startx > startx.log '''2>''' startx.err</div> | ||
Ligne 574 : | Ligne 577 : | ||
Linux est ''multitâches'', ce qui signifie que plusieurs programmes (qui peuvent être à la fois des applications utilisateur ou des tâches système) peuvent tourner simultanément. On vient de voir qu'on pouvait lancer directement depuis un terminal texte une commande en tâche de fond, avec le symbole &. <br /> Comment gère-t-on ensuite ces processus ? | Linux est ''multitâches'', ce qui signifie que plusieurs programmes (qui peuvent être à la fois des applications utilisateur ou des tâches système) peuvent tourner simultanément. On vient de voir qu'on pouvait lancer directement depuis un terminal texte une commande en tâche de fond, avec le symbole &. <br /> Comment gère-t-on ensuite ces processus ? | ||
'''Lister les processus : < | '''Lister les processus : <b>ps</b>''' | ||
La liste des processus en cours pour un terminal donné s'obtient en tapant simplement la commande '''< | La liste des processus en cours pour un terminal donné s'obtient en tapant simplement la commande '''<b>ps</b>''' : | ||
<div class="code"> PID TTY STAT TIME COMMAND<br /> 12 p1 S 0:00 bash<br /> 144 p1 S 0:01 emacs<br /> 1768 p1 R 0:00 ps</div> | <div class="code"> PID TTY STAT TIME COMMAND<br /> 12 p1 S 0:00 bash<br /> 144 p1 S 0:01 emacs<br /> 1768 p1 R 0:00 ps</div> | ||
Si vous voulez voir plus de processus, vous pouvez lister tous les processus d'un utilisateur par < | Si vous voulez voir plus de processus, vous pouvez lister tous les processus d'un utilisateur par <b>ps U root</b> : | ||
<div class="code"> PID TTY STAT TIME COMMAND<br /> 1 ? S 0:04 init<br /> 2 ? SW 0:00 [keventd]<br /> 3 ? SWN 0:00 [ksoftirqd_CPU0]<br /> ...</div> | <div class="code"> PID TTY STAT TIME COMMAND<br /> 1 ? S 0:04 init<br /> 2 ? SW 0:00 [keventd]<br /> 3 ? SWN 0:00 [ksoftirqd_CPU0]<br /> ...</div> | ||
Vous pouvez aussi voir l'ensemble des process d'un système par < | Vous pouvez aussi voir l'ensemble des process d'un système par <b>ps aux</b> | ||
'''Lister les jobs et les gérer : < | '''Lister les jobs et les gérer : <b>jobs</b>, <b>fg</b>, <b>bg</b>''' | ||
"job" est un mot qui désigne ici les programmes que vous avez lancé en arrière plan (tâche de fond) dans votre terminal. Pour lancer un job en arrière plan, vous pouvez : | "job" est un mot qui désigne ici les programmes que vous avez lancé en arrière plan (tâche de fond) dans votre terminal. Pour lancer un job en arrière plan, vous pouvez : | ||
lancer le programme par son nom, puis taper <span class="key">Ctrl-Z</span> pour le stopper, puis la commande '''< | lancer le programme par son nom, puis taper <span class="key">Ctrl-Z</span> pour le stopper, puis la commande '''<b>bg</b>''' pour l'envoyer en arrière plan (BackGround). | ||
vous pouvez aussi simplement taper le nom de ce programme suivi par le symbole '''&'''. | vous pouvez aussi simplement taper le nom de ce programme suivi par le symbole '''&'''. | ||
Afin d'afficher une liste des jobs d'un terminal, tapez la commande '''< | Afin d'afficher une liste des jobs d'un terminal, tapez la commande '''<b>jobs</b>'''<nowiki>:</nowiki> | ||
<div class="code">'''[user@localhost user]$''' find / -name "*a*" >A &<br /> [1] 7859<br />'''[user@localhost user]$''' jobs<br /> [1]+ Running find / -name "*a*" >A & </div> | <div class="code">'''[user@localhost user]$''' find / -name "*a*" >A &<br /> [1] 7859<br />'''[user@localhost user]$''' jobs<br /> [1]+ Running find / -name "*a*" >A & </div> | ||
Pour chacun de ces jobs, vous pouvez les faire revenir en avant plan avec la commande '''< | Pour chacun de ces jobs, vous pouvez les faire revenir en avant plan avec la commande '''<b>fg</b>''' ; "<b>fg</b>" pour le dernier programme lancé en tâche de fond, "<b>fg %n</b>" pour le n<sup>ième</sup>. | ||
'''Tuer un processus : < | '''Tuer un processus : <b>kill</b>, <b>killall</b>''' | ||
Afin de terminer un processus qui ne répond plus, par exemple, on utilise la commande '''< | Afin de terminer un processus qui ne répond plus, par exemple, on utilise la commande '''<b>kill</b>''', suivie du numéro de job (<b>%n</b>) ou du PID du programme à tuer. Par exemple, si <b>ps</b> donne le résultat ci-dessus, la commande "<b>kill 144</b>" arrêtera la tâche emacs. "<b>kill %1</b>" fera la même chose. | ||
Vous pouvez également tuer des processus par leur nom avec la commande '''< | Vous pouvez également tuer des processus par leur nom avec la commande '''<b>killall</b>''' suivie du nom du processus à tuer, mais attention : TOUS les processus de l'utilisateur utilisant killall et portant le même nom seront tués. Par exemple, si vous tapez "<b>killall emacs</b>", non seulement la fenêtre emacs lancée depuis ce terminal sera supprimée, mais aussi tous les autres emacs lancés depuis un autre terminal par l'utilisateur. | ||
Vous pouvez aussi passer un autre argument à kill et killall, qui est le ''signal'' à envoyer à la tâche (les ''signaux'' sont une manière de communiquer avec les applications sous Unix). Par exemple, si la tâche récalcitrante ne s'arrête pas avec un simple < | Vous pouvez aussi passer un autre argument à kill et killall, qui est le ''signal'' à envoyer à la tâche (les ''signaux'' sont une manière de communiquer avec les applications sous Unix). Par exemple, si la tâche récalcitrante ne s'arrête pas avec un simple <b>kill 144</b>, essayez <b>kill -9 144</b>, ou <b>kill -QUIT 144</b>. | ||
---- | ---- | ||
Ligne 614 : | Ligne 617 : | ||
=== Aliases === | === Aliases === | ||
Plutôt que de taper de longues commandes, ou bien parce que vous préférez vous rappeler d'un nom plutôt que du vrai nom Unix, vous pouvez définir des ''aliases''. Pour ce faire, utilisez la commande < | Plutôt que de taper de longues commandes, ou bien parce que vous préférez vous rappeler d'un nom plutôt que du vrai nom Unix, vous pouvez définir des ''aliases''. Pour ce faire, utilisez la commande <b>alias</b> comme suit : | ||
Si votre shell est '''bash''' ou sh ou ash (par défaut) : | Si votre shell est '''bash''' ou sh ou ash (par défaut) : | ||
Ligne 624 : | Ligne 627 : | ||
<div class="code">alias md mkdir <br /> alias ls 'ls --color' <br /> alias eclip2 'telnet eclip2.ec-lille.fr'</div> | <div class="code">alias md mkdir <br /> alias ls 'ls --color' <br /> alias eclip2 'telnet eclip2.ec-lille.fr'</div> | ||
Ainsi pourrez-vous taper < | Ainsi pourrez-vous taper <b>md</b> au lieu de <b>mkdir</b>, et <b>eclip2</b> pour vous connecter à cette machine via telnet ; la commande <b>ls</b> affichera une sortie en couleurs... | ||
Le problème est que les aliases définis dans un terminal ne sont valables que dans celui-ci, et disparaîtrons à jamais dès que ce terminal sera fermé. Pour conserver des alias par-delà les connexions/déconnexions, regardez la [#configuration_shell configuration du shell] : vous pouvez définir vos aliases dans le fichier '''~/.bashrc'''. | Le problème est que les aliases définis dans un terminal ne sont valables que dans celui-ci, et disparaîtrons à jamais dès que ce terminal sera fermé. Pour conserver des alias par-delà les connexions/déconnexions, regardez la [#configuration_shell configuration du shell] : vous pouvez définir vos aliases dans le fichier '''~/.bashrc'''. | ||
Ligne 630 : | Ligne 633 : | ||
=== Variables d'environnement, Path et Prompt === | === Variables d'environnement, Path et Prompt === | ||
Les variables d'environnement servent à enregistrer des paramètres que les programmes peuvent lire ensuite. Elles sont désignées par un symbole < | Les variables d'environnement servent à enregistrer des paramètres que les programmes peuvent lire ensuite. Elles sont désignées par un symbole <b>$</b> suivi de lettres, chiffres et symboles. | ||
Par exemple, la variable < | Par exemple, la variable <b>$HOME</b> est égale au répertoire maison de l'utilisateur en cours (en général <b>/home/user</b>). | ||
De même, la variable < | De même, la variable <b>$PATH</b> représente le chemin de recherche que le shell va parcourir afin de trouver le fichier exécutable qui correspond à la commande que vous venez de taper. Par exemple, <b>$PATH = /bin:/usr/bin:/usr/local/bin</b>. | ||
'''Créer ou modifier une variable d'environnement'''<br /> Si votre shell est '''bash''' ou sh ou ash (par défaut) : | '''Créer ou modifier une variable d'environnement'''<br /> Si votre shell est '''bash''' ou sh ou ash (par défaut) : | ||
Ligne 644 : | Ligne 647 : | ||
<div class="code">setenv MAVARIABLE mavaleur</div> | <div class="code">setenv MAVARIABLE mavaleur</div> | ||
Cette commande positionnera la variable < | Cette commande positionnera la variable <b>MAVARIABLE</b> à la valeur <b>mavaleur</b>. Vous pouvez le vérifier, en tapant la commande <b>echo $MAVARIABLE</b> qui écrira à l'écran "<b>mavaleur</b>". | ||
Vous pouvez ainsi ajouter le chemin < | Vous pouvez ainsi ajouter le chemin <b>/home/user/bin</b> à votre <b>$PATH</b> si vous installez des logiciels dans votre répertoire personnel par exemple. Sous bash, cela donnera : export <b>PATH=$PATH:/home/user/bin</b>. Cependant, de même que pour les aliases, ce nouveau PATH sera perdu dès votre déconnexion... | ||
Attention, en général, le répertoire courant '< | Attention, en général, le répertoire courant '<b>.</b>' ne fait pas partie du PATH pour des raisons de sécurité : imaginez qu'une personne mal intentionnée aie mis un programme destructeur appelé "<b>ls</b>" dans votre répertoire, vous le lanceriez dès que vous taperiez la commande <b>ls</b> ! C'est pourquoi il faut toujours faire précéder de son chemin complet une commande qui n'est pas dans le PATH, et ce même si vous êtes dans le même répertoire que la commande ! Ainsi, il ne faut pas taper <b>configure</b>, mais <b>./configure</b> (programme classique à lancer avant compilation d'un logiciel), ce qui signifie : lance le programme '<b>configure</b>' qui est présent dans le répertoire courant. | ||
Le '''prompt''' est également contenu dans une variable d'environnement : < | Le '''prompt''' est également contenu dans une variable d'environnement : <b>PS1</b>. <br /> Le prompt par défaut de la Mandrake par exemple, <b>[user@localhost user]$</b>, est défini comme suit : <b>PS1="[u@h W]$ "</b>. <br /><b>u</b> est l'utilisateur, <b>h</b> le nom de machine (hostname), <b>w</b> le chemin courant (ex : <b>/usr/doc</b>), <b>W</b> le répertoire courant (ex : <b>doc</b>)... voyez <b>man bash</b> pour l'ensemble des possibilités. | ||
Une autre variable d'environnement utile : PROMPT_COMMAND. Cette variable contient une commande qui est exécutée à chaque fois que le prompt est affiché. Cela permet des tas de fantaisies rigolotes, comme par exemple de jouer un son (trop utile :-) ou de positionner le titre d'un xterm avec le nom du répertoire courant (voir < | Une autre variable d'environnement utile : PROMPT_COMMAND. Cette variable contient une commande qui est exécutée à chaque fois que le prompt est affiché. Cela permet des tas de fantaisies rigolotes, comme par exemple de jouer un son (trop utile :-) ou de positionner le titre d'un xterm avec le nom du répertoire courant (voir <b>man xterm</b>). | ||
Regardez la [#configuration_shell configuration du shell] : vous pouvez définir vos variables dans le fichier < | Regardez la [#configuration_shell configuration du shell] : vous pouvez définir vos variables dans le fichier <b>~/.bash_profile</b>. | ||
---- | ---- | ||
Ligne 662 : | Ligne 665 : | ||
Vous pouvez enregistrer des fichiers qui seront lus et exécutés par votre shell, lors de l'ouverture d'un terminal, aussi bien que lors de sa fermeture. Cela va vous permettre d'y placer vos aliases préférés, et vos variables d'environnement. | Vous pouvez enregistrer des fichiers qui seront lus et exécutés par votre shell, lors de l'ouverture d'un terminal, aussi bien que lors de sa fermeture. Cela va vous permettre d'y placer vos aliases préférés, et vos variables d'environnement. | ||
Pour '''bash''' et consorts, ces fichiers s'appellent : < | Pour '''bash''' et consorts, ces fichiers s'appellent : <b>.bashrc</b>, <b>.bash_profile</b> pour la connexion et <b>.bash_logout</b> pour la déconnexion. <br /> Pour '''tcsh''' et ses potes, ces fichiers s'appellent : <b>.tcshrc</b>, <b>.login</b> pour la connexion et <b>.logout</b> pour la déconnexion. <br /> Ces fichiers se situent tous dans le répertoire maison de l'utilisateur ($HOME). Notez bien qu'ils commencent par un point : ce sont des fichiers cachés. Pour les voir, il faut faire un "<b>ls -a</b>". | ||
Examinez les avec votre éditeur de texte préféré, et vous verrez comment ajouter de nouveaux aliases et variables d'environnement, ainsi que lancer tel ou tel programme automatiquement : en tant que ''scripts shell'', ces programmes sont en fait une suite d'instructions qui sera interprétée par le shell. | Examinez les avec votre éditeur de texte préféré, et vous verrez comment ajouter de nouveaux aliases et variables d'environnement, ainsi que lancer tel ou tel programme automatiquement : en tant que ''scripts shell'', ces programmes sont en fait une suite d'instructions qui sera interprétée par le shell. | ||
Ligne 684 : | Ligne 687 : | ||
On se rend donc compte qu'un caractère spécial peut être interprété par le shell avant d'être interprété au sein de la commande. | On se rend donc compte qu'un caractère spécial peut être interprété par le shell avant d'être interprété au sein de la commande. | ||
'''Exemple''' : le caractère < | '''Exemple''' : le caractère <b>"*"</b> peut être interprété par le shell (remplace 0 ou n caractères pour compléter un nom de fichier) ou par une commande comme <b>grep</b> (répète de 0 à n fois le caractère précédent dans une chaîne de caractères). Toutefois, sans précision dans la synthaxe, et selon les étapes ci-dessus, le caractère sera d'abord interprété par le shell. D'où quelques surprises dans le résultat de la commande. | ||
=== L'interprétation des caractères spéciaux === | === L'interprétation des caractères spéciaux === | ||
Ligne 699 : | Ligne 702 : | ||
exemple : recherche des lignes d'un script utilisant la variable PATH | exemple : recherche des lignes d'un script utilisant la variable PATH | ||
<div class="code">'''[user@localhost user]$''' grep $PATH /home/user/script <br />'''[user@localhost user]$'''</div> | <div class="code">'''[user@localhost user]$''' grep $PATH /home/user/script <br />'''[user@localhost user]$'''</div> | ||
Au premier passage, le shell interprète le '''$''' comme introduisant une variable. Il remplace donc la variable par son contenu puis exécute la commande < | Au premier passage, le shell interprète le '''$''' comme introduisant une variable. Il remplace donc la variable par son contenu puis exécute la commande <b>grep</b>. Il ne trouve donc aucune ligne comportant les chemins référencés dans PATH. | ||
<div class="code">'''[user@localhost user]$''' grep '$PATH' /home/user/script <br /> echo $PATH <br />'''[user@localhost user]$''' </div> | <div class="code">'''[user@localhost user]$''' grep '$PATH' /home/user/script <br /> echo $PATH <br />'''[user@localhost user]$''' </div> | ||
Le shell n'interprète pas le '''$''' lors du premier passage car sa signification est annulée par les simples quotes. le $ est donc traité par la commande grep. Comme il n'a pas de signification particulière, il est interprété comme un caractère quelconque. | Le shell n'interprète pas le '''$''' lors du premier passage car sa signification est annulée par les simples quotes. le $ est donc traité par la commande grep. Comme il n'a pas de signification particulière, il est interprété comme un caractère quelconque. | ||
Ligne 821 : | Ligne 824 : | ||
Pour terminer 2 commandes utiles pour savoir à quel type de commande vous avez à faire : | Pour terminer 2 commandes utiles pour savoir à quel type de commande vous avez à faire : | ||
* | * '''<b>type nom_de_commande</b>''' : permet de déterminer le type d'une commande (alias, fonction, commande interne...) | ||
* | * '''<b>which nom_de_commande</b>''' : recherche le chemin de la commande dans PATH | ||
exemples : | exemples : | ||
<div class="code">'''[user@localhost user]$''' type ls <br /> ls est un alias suivi pour /usr/bin/ls <br />'''[user@localhost user]$''' type cd <br /> cd est une commande prédéfinie du shell <br />'''[user@localhost user]$''' which pwd <br /> /usr/bin/pwd <br /> </div> | <div class="code">'''[user@localhost user]$''' type ls <br /> ls est un alias suivi pour /usr/bin/ls <br />'''[user@localhost user]$''' type cd <br /> cd est une commande prédéfinie du shell <br />'''[user@localhost user]$''' which pwd <br /> /usr/bin/pwd <br /> </div> | ||
Ligne 830 : | Ligne 833 : | ||
== Index des commandes == | == Index des commandes == | ||
heu... bon là j'en ai marre, on verra ça plus tard ! < | heu... bon là j'en ai marre, on verra ça plus tard ! <b><nowiki>:-)</nowiki></b> | ||
Je place quand même ici 2 commandes qui peuvent être bien utiles : | Je place quand même ici 2 commandes qui peuvent être bien utiles : | ||
'''< | '''<b>cal</b>''' : donne le calendrier du mois courant, <br /><b>cal 12 1999</b> : donne le calendrier de décembre 1999, <br /><b>cal 2000</b> : donne le calendrier des 12 mois de l'an 2000. | ||
< | <b>factor 12456988</b> : donne la décomposition en produit de facteurs premiers du nombre 12456988 (soit 2 x 2 x 17 x 183191) - c'est très mathématique, mais ultra rapide et puissant. | ||
Pour terminer cet article, je vous renvoie vers ce petit manuel de référence, qui contient l'ensemble des commandes usuelles : | Pour terminer cet article, je vous renvoie vers ce petit manuel de référence, qui contient l'ensemble des commandes usuelles : | ||
* [http://www.softndesign.org/?page=manuels/unix-1. | * [http://www.softndesign.org/?page=manuels/unix-1.php Débuter en shell] {{flag-fr}}, | ||
* [http://www.softndesign.org/?page=manuels/unix-2. | * [http://www.softndesign.org/?page=manuels/unix-2.php Petit manuel de référence] {{flag-fr}}, | ||
* [http://www.softndesign.org/?page=manuels/unix-3. | * [http://www.softndesign.org/?page=manuels/unix-3.php Pour aller plus loin] {{flag-fr}}. | ||
et aussi : | et aussi : | ||
* [http://club.mandriva.com/xwiki/bin/KB/BasicsIndex# | * [http://club.mandriva.com/xwiki/bin/KB/BasicsIndex#shell Les bases du shell] {{flag-fr}} | ||
<br/> | |||
<br/> | |||
'''<b>[[Admin-index|@ Retour à la rubrique Administration système]]</b>''' | |||
<br/> | |||
<div class="merci">Cette page est issue de la documentation 'pré-wiki' de Léa a été convertie avec HTML::WikiConverter. Elle fut créée par Jean-Christophe Cardot le 02/11/1999.</div> | <div class="merci">Cette page est issue de la documentation 'pré-wiki' de Léa a été convertie avec HTML::WikiConverter. Elle fut créée par Jean-Christophe Cardot le 02/11/1999.</div> | ||
{{Copy|02/11/1999|[[Utilisateur:Jice|Jean-Christophe Cardot]], [mailto:SPI.MJ%20%3Cspi.mj%20chez%20wanadoo.fr%3E Marc] et [[Utilisateur:Ennael|Anne Nicolas]]|CC-BY-SA}} | |||
Dernière version du 28 avril 2012 à 15:38
Le shell ou le retour du C:\> ! (et les commandes)
par Jean-Christophe, complété par Marc et Anne
Le shell, un environnement écrit au temps ou les hommes étaient des hommes :-)
Introduction
Qu'est-ce que shell me direz vous ? Certains diront que c'est ça le vrai Linux. il n'y a pas que du faux là-dedans, puisque étymologiquement parlant, "Linux" est juste le nom du noyau du système d'exploitation, et qu'on a tendance par abus de langage à utiliser "Linux" pour désigner l'ensemble de Linux, du serveur X et des nombreuses applications.
Bref, le shell c'est le bon vieux mode texte, mon copain le prompt, qui sous Linux revêt une importance capitale. En effet, la philosophie Unix veut que toute action puisse être réalisée en ligne de commande, avant d'être accessible dans une boîte de dialogue. Ainsi de nombreuses applications X ne sont en fait que des front ends (des façades) à des applications en ligne de commande, se contentant de construire la bonne ligne de commande à partir de vos clics (XCDRoast / cdrecord, mkisofs, etc. ; kppp / pppd ; etc.).
Comme Linux prône le règne de la liberté, vous n'avez pas qu'un seul shell disponible. Vous pouvez utiliser bash, tcsh, ksh, ash, sh, csh, etc. Néanmoins, la plupart des distributions actuelles proposent bash par défaut, et je vous recommande donc de l'utiliser, surtout si vous débutez sous Unix et que vous n'avez pas encore d'habitudes. Si plus tard, vous tombez sur un ordinateur ne disposant que de tcsh, ne vous inquiétez pas : la différence n'est pas flagrante, et vous pourrez toujours consulter "man tcsh" !
à noter que le choix du shell pour un utilisateur se configure dans /etc/passwd.
Le shell n'est pas seulement le prompt vous permettant de taper vos commandes, c'est aussi un puissant langage de commande, vous permettant d'automatiser des tâches, etc. via l'écriture de scripts shell. Apprendre le langage du shell peut être très enrichissant et utile ; néanmoins, cela dépasse le cadre de cette rubrique. Et puis je n'ai pas le courage de taper une leçon sur bash :) Par contre, vous trouverez ici les commandes de base, ainsi que les raccourcis clavier et les raccourcis du shell, les aliases, les variables d'environnement, la configuration du shell et j'en passe. C'est déjà pas mal non ?
Commandes pour débuter
Avant de commencer, il faut savoir que Linux est sensible à la casse (case sensitive en anglais), c'est à dire qu'il distingue les majuscules des minuscules. Ainsi, si je vous dit que la commande est 'mkdir', ce n'est pas la peine d'essayer MKDIR ou mKdiR, cela ne fonctionnera pas. De même, les noms de fichiers et de répertoires sont également sensibles à la casse.
De plus, sous Unix, les chemins sont séparés par des slash : écrivez /etc/rc.d/init.d/xfs mais jamais etc\rc.d\init.d\xfs par pitié :)
- Répertoires spéciaux :
. représente le répertoire courant, .. représente le répertoire parent ~ représente le répertoire maison (home) de l'utilisateur
- Fichiers cachés :
sous Unix, les fichiers cachés commencent par un point. Par exemple, ~/.bashrc est un fichier caché, dans le répertoire maison de l'utilisateur, qui contient la configuration de son shell.
- Jokers : ? et *
Les caractères ? et * dans les noms de fichiers et de répertoires permettent de représenter des caractères quelconques. '?' représente un seul caractère, tandis que '*' en représente un nombre quelconque. Par exemple "*.jpg" représente tous les fichiers se terminant par jpg ; "*toto*" tous les fichiers contenant "toto". Oui vous avez bien vu : on peut mettre plusieurs étoiles en même temps !!! Vous pouvez même faire : cd /et*/rc.*/init*, cela risque de fonctionner !!! Il faut également savoir que c'est le shell qui interprète ces caractères avant de transmettre la ligne de commande. Par exemple, si vous tapez : rm -Rf *.tmp, le shell transformera cette ligne de commande en : rm truc1.tmp truc2.tmp truc3.tmp.
- Jokers avancés : []
Vous pouvez aussi utiliser les crochets pour spécifier des caractères : [a] signifie : égal à 'a'. Exemple : rm *[a]* efface tous les fichiers contenant la lettre 'a'. [!a] signifie : différent de 'a'. Exemple : rm *[!a]* efface tous les fichiers, sauf ceux contenant la lettre 'a'. [abc] signifie : l'un des caractères a, b ou c. Exemple : rm [abc]*.tmp efface tous les fichiers commençant par a, b ou c. [a-l] : signifie : tous les caractères compris entre a et l. Exemple : rm fic_[a-l]* efface tous les fichiers commençant par fic_ suivi d'une quelconque lettre entre a et l.
Bon c'est pas tout ça, voici les commandes de base sous Linux :
Commandes linux |
équivalent MsDos |
à quoi ça sert |
Exemples : |
cd |
cd |
change le répertoire courant. |
cd .. cd /home/user/.nsmail |
ls |
dir |
affiche le contenu d'un répertoire |
ls ls -l ls -a /home/user |
cp |
copy |
copie un ou plusieurs fichiers |
cp toto /tmp cp toto titi cp -R /home/user /tmp/bak |
rm |
del |
efface un ou plusieurs fichiers |
rm toto titi rm -f toto titi |
rm -rf |
deltree |
efface un répertoire et son contenu |
rm -rf /tmp/* |
mkdir |
md ou mkdir |
crée un répertoire |
mkdir /home/user/mes_documents |
rmdir |
rm |
efface un répertoire s'il est vide |
rmdir /home/user/.nsmail |
mv |
ren |
déplace ou renomme un ou des fichiers |
mv tata titi mv * *.bak mv * /tmp/bak |
find |
dir -s |
trouve un fichier répondant à certains critères |
find /home -name "*bash*" |
locate |
dir -s |
trouve un fichier d'après son nom |
locate bash |
man |
help |
affiche l'aide concernant une commande particulière |
man ls |
chmod |
cacls |
modifie les permissions d'un fichier |
chmod o+r /home/user chmod a+rw /home/user/unfichier |
chown |
pas |
modifie le propriétaire d'un fichier |
chown user unfichier |
chgrp |
pas |
modifie le groupe proprétaire d'un fichier |
chgrp -R nobody /home/httpd |
ln -s |
pas |
crée un lien vers un fichier |
ln -s /dev/fd0 /dev/disquette |
grep |
pas |
recherche une chaine dans un fichier (en fait recherche une expression régulière dans plusieurs fichiers) |
grep chaine *.txt |
which |
pas |
trouve le répertoire dans lequel se trouve une commande |
which emacs |
cat |
type |
affiche un fichier à l'écran |
cat ~/.bashrc |
Remarque :
Pour en savoir plus sur toutes ces commandes, je vous conseille de consulter leur page de man !
La commande ls
Cette commande est omniprésente, aussi il est bon d'en présenter les basiques.
Afficher le listing page par page : ls | less (less est une version améliorée de more)
Afficher le listing en couleurs : ls --color
Afficher aussi les fichiers cachés (commençant par un point) : ls -a
Mettre un '/' après les noms de répertoires : ls -p
Afficher le listing détaillé : ls -l
Tri sur la date
Pour afficher les fichiers d'un répertoire en triant sur la date de mise à jour des fichiers
Afficher les fichiers les plus récents en premier : ls -t
Afficher les fichiers les plus vieux en premier : ls -rt
Mixer avec l'option "l" afin d'afficher le listing détaillé : ls -rtl ou ls -tl
bien sûr, toutes ces options sont mixables, ainsi "ls -altp" affiche tous les fichiers, de façon détaillée, dans l'ordre chronologique, an ajoutant '/' après chaque nom de répertoire.
Exemple de listing
total 144
-rw-r--r-- 1 jice users 24 Aug 2 21:37 .bash_logout
-rw-r--r-- 1 jice users 230 Aug 2 21:37 .bash_profile
-rw-r--r-- 1 jice users 467 Aug 2 21:37 .bashrc
-rw-r--r-- 1 jice users 1452 Aug 2 21:37 .kderc
drwxr--r-- 12 jice users 1024 Aug 2 21:37 .kde/
drwxr--r-- 2 jice users 1024 Aug 2 21:37 Desktop/
-rw-r----- 1 jice users 1728 Aug 2 21:37 adresses.txt
-rw------- 1 jice users 144 Aug 2 21:37 motsdepasse.txt
lrwxrwxrwx 1 jice users 14 Aug 2 21:37 linux -> /usr/src/linux
Explication :
La première ligne "total 144" est l'espace disque utilisé par l'ensemble des fichiers du répertoire.
- La première colonne -rw-r--r--représente les permissions associées au fichier. le premier caractère est un tiret pour un fichier, un d pour un répertoire, un l pour un lien, etc.
ensuite, on a trois groupes de trois caractères : rw- ou r-- ou rwx ou...
Le premier groupe représente les permissions associées à l'utilisateur (ici, jice), le deuxième celles associées à son groupe (ici : users), enfin le dernier est les permissions que tout le monde a sur ces fichiers.
r signifie : possibilité de lire ce fichier / dans ce répertoire,
w signifie : possibilité d'écrire dans ce fichier / répertoire,
x signifie : possibilité d'exécuter ce fichier / d'aller dans ce répertoire. - nombre d'inodes (partie élémentaire de [../docs/glossaire.php3#systeme_fichiers système de fichiers]) qui pointent vers le fichier/répertoire (généralement 1 pour un fichier, 2+le nombre de sous-répertoires pour un répertoire).
- utilisateur à qui appartient le fichier (jice)
- groupe auquel le fichier appartient (users)
- taille en octets
- date et heure de modification
- nom du fichier/répertoire.
Quelques questions et réponses
Les commandes du tableau ci-dessus permettent de répondre à quelques questions comme :
Où est cette commande (which) ? Que contient ce fichier (cat ou tac) ? Quel fichier contient tel mot (grep) ? etc.
Voici d'autres questions et réponses qui ne nécessitent pas d'être root et vous permettront de continuer à vous familiariser avec bash et ses commandes. Elles sont regroupées en trois tableaux : Informations sur les commandes ; informations sur le système ; informations sur les fichiers.
Informations sur les commandes
Quelle commande utiliser pour faire ... ceci ou cela ? |
apropos mot_clef ou man -k mot_clef Notes : les noms communs et les verbes à l'infinitif permettent généralement de trouver facilement la commande recherchée. En cas d'échec, pensez aux synonymes : apropos supprimer fait apparaître la commande rmdir (supprimer un répertoire), alors que apropos effacer fait apparaître la commande rm (effacer un fichier). |
Comment se définit cette commande ? |
whatis nom_commande ou man -f nom_commande Notes : dans l'exemple précédant vous pouvez bien sûr remplacer /bin par /sbin ; certaines entrées échouent. |
Quelles sont et comment utiliser les commandes internes ? |
help Notes : ces commandes sont les commandes internes du shell, généralement le bash. Vous pouvez aussi en obtenir la liste en demandant à propos de l'une d'elles une page man qui n'existe pas (man :). Vous trouverez également une aide sur les commandes internes dans la page man de bash (man bash). Enfin notez que help concerne les commandes internes mais --help les commandes externes. |
|
ls /bin Notes : les répertoires /usr/bin/ et /usr/sbin/ contiennent les commandes externes moins fréquemment utilisées. Pour savoir si une commande est externe vous pouvez aussi simplement vérifier qu'elle n'est pas interne ! |
Comment obtenir un aide mémoire sur cette commande ? |
nom_commande --help Notes : --help concerne la plupart des commandes externes et help les commandes internes. echo --help affiche bien sûr ... --help. |
La dernière commande s'est-elle bien terminée ? |
echo $? Notes : commande1 && commande2 exécute commande2 que si commande1 s'est terminée normalement (0) ; commande1 || commande2 exécute commande2 que si commande1 ne s'est pas terminée correctement (<>0). |
Quels sont le nom, la taille et le contenu du fichier d'historique ? |
echo $HISTFILE $HISTFILESIZE Notes : le fichier d'historique vous aide à répondre à la question : mais comment j'avais fait ? et à en conserver une trace d'une connexion à l'autre. |
Quel est l'historique actuel ? |
history | more Notes : c'est cet historique qui défile avec les touches "flèches" de votre clavier ; au démarrage, c'est le contenu de votre fichier d'historique. |
Informations sur le système
Quel est le système ? |
uname ou echo $OSTYPE Notes : les informations recueillies avec uname -a peuvent aussi être obtenues avec certaines variables système : echo $OSTYPE $BASH $BASH_VERSION etc. |
Depuis combien de temps ce shell est-il actif ? |
uptime Notes : bash ne connaît que les entiers et donc que les divisions euclidiennes, / permet d'en obtenir le quotient et % d'en obtenir le reste (ou modulo). Chaque fois que vous changez de terminal, ouvrez un nouvel xterm ou faites un su, celui-ci correspond à un nouveau (sous)shell, sa variable SECONDS est donc alors à 0. Pour savoir depuis combien de temps vous êtes sous Linux, revenez à votre console de login ; pour savoir depuis quand le système est actif, utilisez uptime. |
Qu'en est-il des disques, de la mémoire, du microprocesseur ? |
mount Notes : la touche |
Quelles sont et que signifient les variables système ? |
$<Tab> Notes : les noms des variables système sont généralement écrits en majuscules. A chacune de ces variables correspond une question et une réponse, quelques unes seulement ont été formulées à divers endroits dans cette page. |
Que contiennent ces variables système ? |
echo $NOM_VARIABLE Notes : vous pouvez bien sûr modifier le prompt PS1="chaîne de caractères". Pour rendre cette modification générale et durable, il faut utiliser le fichier /etc/bashrc (nécessite d'être root). |
Qui suis-je et qui est ou était connecté au système ? |
id nom_utilisateur Notes : la commande who am i ne fonctionne pas toujours sous xterm, dans ce cas entrez whoami mais vous n'obtiendrez que votre nom de login. De nombreuses commandes permettent d'obtenir une partie des renseignements évoqués ci-dessus, leurs noms parlent d'eux-mêmes : logname, users, groups ... |
Quelles sont la date et l'heure ? |
date |
Y a-t-il un manchot dans le système ? |
linux_logo Notes : sur mon système, linux_logo -la produit bien l'affichage attendu (-a = ASCII et -l = pas d'informations) mais avec linux_logo -al, l'option -l est ignorée et les informations sont affichées ... Y a-t-il un bug dans mon système ? |
Informations sur les fichiers
Quel est le répertoire courant ? |
pwd |
Quelle est la taille de ce répertoire ? |
du -sh Notes : du ne fonctionne que sur les répertoires où vous avez droit d'accès, si nécessaire passez sous root. |
Quel est le type de ce fichier ? |
file nom_fichier Notes : file sait reconnaître un grand nombre de types de fichiers parmi les fichiers spéciaux, exécutables, textes, données ... Il est préférable de l'utiliser avant d'entrer un "cat" au hasard. |
Raccourcis
Clavier
- Tab
Taper une fois la touche [Tab] permet de compléter automatiquement un nom de fichier/répertoire s'il est unique :
[user@localhost user]$ cd /etc_
- Tab Tab
Si lors du premier appui sur [Tab], le nom n'a pas été complété, un deuxième appui vous donne la liste de toues les possibilités :
HTML HOWTO
[user@localhost user]$ cd /usr/doc/H_
- Flèche vers le haut (ou Ctrl-P) / bas (ou Ctrl-N)
La flèche vers le haut permet de remonter dans l'historique des commandes, la flèche vers le bas permet de revenir. Vous pouvez aussi utiliser la commande fc, consultez man fc.
- Shift - flèche vers le haut/bas
Permet de scroller le contenu du terminal texte vers le haut ou le bas, d'une ligne. En effet, les lignes qui ont défilé vers le haut restent en mémoire et restent accessibles. Terrible, non ?
- Shift - Page up/down
La même chose, mais page par page.
- Ctrl-C
Arrête le processus en cours, celui qui a été lancé par la dernière commande.
- Ctrl-Z
Stoppe le processus en cours, celui qui a été lancé par la dernière commande, mais ne le détruit pas : il reste en attente. Pour le mettre en tâche de fond (il continue à s'exécuter, mais vous pouvez continuer à taper des commandes), tapez bg. Pour le faire revenir en avant, taper fg.
- Ctrl-D
Ferme le terminal en cours (similaire à exit ou logout).
et aussi...
- Ctrl-Alt-Fn
Se place sur la console virtuelle numéro n. Par défaut, il y a en général 6 consoles texte virtuelles, de F1 à F6, et X Window se lance dans la septième (F7).
- Ctrl-Alt-Backspace
Cela permet de tuer X et de revenir soit à la [../docs/glossaire.php3#display_manager bannière de login] soit au shell qui a lancé X par startx. A éviter si possible : il est plus sain de quitter X en se déconnectant proprement.
- Ctrl-Alt-Del
Suivant votre configuration, ces touches à l'action bien connue vous permettrons de rebooter votre ordinateur (synonyme de reboot ou shutdown -r now). Si vous souhaitez juste arrêter votre ordinateur afin de l'éteindre, tapez halt, ou shutdown -h now.
Shell
Les shells Unix disposent de petits "raccourcis" très astucieux et utiles, qui vous épargnerons de taper sur quelques touches. Ne dit-on pas qu'un bon informaticien est un informaticien fainéant ? :-)
Dernière ligne de commande : !!
On a vu plus haut qu'elle était accessible par la flèche vers le haut, mais vous pouvez également la désigner par '!!', ce qui peut être très intéressant.
[user@localhost user]$ which !!
which vi
/bin/vi
Arguments de la dernière commande : !*
Les arguments de la dernière commande peuvent être représentés par '!*'.
[user@localhost user]$ cd !
cd test
Utiliser la sortie d'une commande comme argument :
Vous pouvez réutiliser directement ce qu'une commande écrit à l'écran comme argument pour une autre commande. Pour ce faire, vous devez encadrer la commande par une cote inverse ` ou la mettre entre parenthèses précédées du signe $ ; elle sera remplacée par ce qu'elle écrit à l'écran dans la ligne de commande. Imaginez par exemple que vous vouliez voir les informations sur le fichier exécutable de emacs.
[user@localhost user]$ ls -l $(which emacs)
est ainsi équivalent à :
/usr/bin/emacs
[user@localhost user]$ ls -l /usr/bin/emacs
Cool non ? Et vous pouvez mixer les raccourcis vus précédemment :
[user@localhost user]$ ls -l `which !!`
C'est-y pas beau ça madame ?
Remplacer un caractère par un autre : ^
Si vous souhaitez remplacer la première occurrence d'un caractère de la ligne de commande précédente par un autre, vous pouvez utiliser le symbole ^, comme ci-dessous :
lpcate : command not found
[user@localhost user]$ ^p^o
locate i486-linux-libc5
^p^o signifie : refait la même ligne de commande que précédemment, mais remplace le premier p par un o.
Lancer un programme directement en tâche de fond : &
Il suffit de faire suivre la ligne de commande du symbole & :
[1] 7194
[user@localhost user]$ _
La commande est lancée en tâche de fond, c'est à dire qu'elle s'exécute, mais la main vous est rendue tout de suite. La fin de la commande est signifiée par un message :
[1]+ Done cp -R /usr/doc /tmp
[user@localhost user]$ _
Lancer plusieurs programmes en même temps : &, &&, ||, ;
Vous avez plusieurs solutions :
prog1 ; prog2 lance prog1, puis prog2,
prog1 & prog2 lance prog1 en arrière plan, puis immédiatement prog2 en avant plan,
prog1 && prog2 lance prog1, puis prog2 seulement si prog1 n'a pas retourné d'erreur,
prog1 || prog2 lance prog1, puis prog2 seulement si prog1 A retourné une erreur.
Redirections
Normalement, la sortie des programmes se fait à l'écran, aussi bien pour les erreurs (standard error) que pour les messages "normaux" (standard output). Vous pouvez la rediriger, soit vers un fichier avec >, soit vers l'entrée d'un autre programme avec | (ou pipe - attention, arrêtez de rigoler dans le fond :-).
De même, l'entrée standard (standard input) est habituellement constituée du clavier, mais on peut aussi la remplacer par le contenu d'un fichier, avec le symbole <.
Envoyer la sortie standard d'un programme dans l'entrée standard d'un autre
Vous avez déjà certainement vu ou utilisé une commande du type :
ls -la envoie la version longue du listing de répertoire, avec les fichier cachés, à more qui l'affiche page par page.
Vous pouvez aussi enchaîner plusieurs redirections :
Ceci va afficher page par page l'ensemble des messages système relatifs à gpm. (voir plus haut ce que font chacune de ces commandes).
Envoi d'un fichier dans l'entrée standard
L'entrée standard (standard input) est normalement ce que vous tapez au clavier. Vous pouvez remplacer vos frappes clavier par le contenu d'un fichier, qui sera ouvert et envoyé sur l'entrée standard du programme. C'est pratique pour automatiser des tâches avec des programmes interactifs. Exemple :
Ici le fichier sessiontype.txt pourra contenir par exemple :
user jice
pass xxxxxx
cd /pub/linux/doc
bin
get jice.jpg
bye
Et vous permettra en une seule commande de récupérer le fichier jice.jpg sur le site ftp.lesite.com (utile si ce fichier change et que vous voulez le mettre à jour régulièrement). Bref, à vous d'inventer la vie qui va avec :-)
Redirection des sorties vers un fichier
Cette commande va lister le contenu du cdrom, et enregistrer le résultat dans le fichier cdrom.txt.
En mettant deux > de suite, vous ajoutez au fichier :
Ceci va ajouter la date au fichier précédemment créé.
Les messages d'erreur peuvent être dirigés séparément dans un fichier avec 2> :
ou dirigés vers le même fichier que les messages normaux :
Gestion des processus
Linux est multitâches, ce qui signifie que plusieurs programmes (qui peuvent être à la fois des applications utilisateur ou des tâches système) peuvent tourner simultanément. On vient de voir qu'on pouvait lancer directement depuis un terminal texte une commande en tâche de fond, avec le symbole &.
Comment gère-t-on ensuite ces processus ?
Lister les processus : ps
La liste des processus en cours pour un terminal donné s'obtient en tapant simplement la commande ps :
12 p1 S 0:00 bash
144 p1 S 0:01 emacs
1768 p1 R 0:00 ps
Si vous voulez voir plus de processus, vous pouvez lister tous les processus d'un utilisateur par ps U root :
1 ? S 0:04 init
2 ? SW 0:00 [keventd]
3 ? SWN 0:00 [ksoftirqd_CPU0]
...
Vous pouvez aussi voir l'ensemble des process d'un système par ps aux
Lister les jobs et les gérer : jobs, fg, bg
"job" est un mot qui désigne ici les programmes que vous avez lancé en arrière plan (tâche de fond) dans votre terminal. Pour lancer un job en arrière plan, vous pouvez :
lancer le programme par son nom, puis taper Ctrl-Z pour le stopper, puis la commande bg pour l'envoyer en arrière plan (BackGround).
vous pouvez aussi simplement taper le nom de ce programme suivi par le symbole &.
Afin d'afficher une liste des jobs d'un terminal, tapez la commande jobs:
[1] 7859
[user@localhost user]$ jobs
[1]+ Running find / -name "*a*" >A &
Pour chacun de ces jobs, vous pouvez les faire revenir en avant plan avec la commande fg ; "fg" pour le dernier programme lancé en tâche de fond, "fg %n" pour le nième.
Tuer un processus : kill, killall
Afin de terminer un processus qui ne répond plus, par exemple, on utilise la commande kill, suivie du numéro de job (%n) ou du PID du programme à tuer. Par exemple, si ps donne le résultat ci-dessus, la commande "kill 144" arrêtera la tâche emacs. "kill %1" fera la même chose.
Vous pouvez également tuer des processus par leur nom avec la commande killall suivie du nom du processus à tuer, mais attention : TOUS les processus de l'utilisateur utilisant killall et portant le même nom seront tués. Par exemple, si vous tapez "killall emacs", non seulement la fenêtre emacs lancée depuis ce terminal sera supprimée, mais aussi tous les autres emacs lancés depuis un autre terminal par l'utilisateur.
Vous pouvez aussi passer un autre argument à kill et killall, qui est le signal à envoyer à la tâche (les signaux sont une manière de communiquer avec les applications sous Unix). Par exemple, si la tâche récalcitrante ne s'arrête pas avec un simple kill 144, essayez kill -9 144, ou kill -QUIT 144.
Aliases et variables d'environnement
Aliases
Plutôt que de taper de longues commandes, ou bien parce que vous préférez vous rappeler d'un nom plutôt que du vrai nom Unix, vous pouvez définir des aliases. Pour ce faire, utilisez la commande alias comme suit :
Si votre shell est bash ou sh ou ash (par défaut) :
alias ls='ls --color'
alias eclip2='telnet eclip2.ec-lille.fr'
Si votre shell est tcsh ou csh (par défaut) :
alias ls 'ls --color'
alias eclip2 'telnet eclip2.ec-lille.fr'
Ainsi pourrez-vous taper md au lieu de mkdir, et eclip2 pour vous connecter à cette machine via telnet ; la commande ls affichera une sortie en couleurs...
Le problème est que les aliases définis dans un terminal ne sont valables que dans celui-ci, et disparaîtrons à jamais dès que ce terminal sera fermé. Pour conserver des alias par-delà les connexions/déconnexions, regardez la [#configuration_shell configuration du shell] : vous pouvez définir vos aliases dans le fichier ~/.bashrc.
Variables d'environnement, Path et Prompt
Les variables d'environnement servent à enregistrer des paramètres que les programmes peuvent lire ensuite. Elles sont désignées par un symbole $ suivi de lettres, chiffres et symboles.
Par exemple, la variable $HOME est égale au répertoire maison de l'utilisateur en cours (en général /home/user).
De même, la variable $PATH représente le chemin de recherche que le shell va parcourir afin de trouver le fichier exécutable qui correspond à la commande que vous venez de taper. Par exemple, $PATH = /bin:/usr/bin:/usr/local/bin.
Créer ou modifier une variable d'environnement
Si votre shell est bash ou sh ou ash (par défaut) :
Si votre shell est tcsh ou csh (par défaut) :
Cette commande positionnera la variable MAVARIABLE à la valeur mavaleur. Vous pouvez le vérifier, en tapant la commande echo $MAVARIABLE qui écrira à l'écran "mavaleur".
Vous pouvez ainsi ajouter le chemin /home/user/bin à votre $PATH si vous installez des logiciels dans votre répertoire personnel par exemple. Sous bash, cela donnera : export PATH=$PATH:/home/user/bin. Cependant, de même que pour les aliases, ce nouveau PATH sera perdu dès votre déconnexion...
Attention, en général, le répertoire courant '.' ne fait pas partie du PATH pour des raisons de sécurité : imaginez qu'une personne mal intentionnée aie mis un programme destructeur appelé "ls" dans votre répertoire, vous le lanceriez dès que vous taperiez la commande ls ! C'est pourquoi il faut toujours faire précéder de son chemin complet une commande qui n'est pas dans le PATH, et ce même si vous êtes dans le même répertoire que la commande ! Ainsi, il ne faut pas taper configure, mais ./configure (programme classique à lancer avant compilation d'un logiciel), ce qui signifie : lance le programme 'configure' qui est présent dans le répertoire courant.
Le prompt est également contenu dans une variable d'environnement : PS1.
Le prompt par défaut de la Mandrake par exemple, [user@localhost user]$, est défini comme suit : PS1="[u@h W]$ ".
u est l'utilisateur, h le nom de machine (hostname), w le chemin courant (ex : /usr/doc), W le répertoire courant (ex : doc)... voyez man bash pour l'ensemble des possibilités.
Une autre variable d'environnement utile : PROMPT_COMMAND. Cette variable contient une commande qui est exécutée à chaque fois que le prompt est affiché. Cela permet des tas de fantaisies rigolotes, comme par exemple de jouer un son (trop utile :-) ou de positionner le titre d'un xterm avec le nom du répertoire courant (voir man xterm).
Regardez la [#configuration_shell configuration du shell] : vous pouvez définir vos variables dans le fichier ~/.bash_profile.
Configuration du shell
Vous pouvez enregistrer des fichiers qui seront lus et exécutés par votre shell, lors de l'ouverture d'un terminal, aussi bien que lors de sa fermeture. Cela va vous permettre d'y placer vos aliases préférés, et vos variables d'environnement.
Pour bash et consorts, ces fichiers s'appellent : .bashrc, .bash_profile pour la connexion et .bash_logout pour la déconnexion.
Pour tcsh et ses potes, ces fichiers s'appellent : .tcshrc, .login pour la connexion et .logout pour la déconnexion.
Ces fichiers se situent tous dans le répertoire maison de l'utilisateur ($HOME). Notez bien qu'ils commencent par un point : ce sont des fichiers cachés. Pour les voir, il faut faire un "ls -a".
Examinez les avec votre éditeur de texte préféré, et vous verrez comment ajouter de nouveaux aliases et variables d'environnement, ainsi que lancer tel ou tel programme automatiquement : en tant que scripts shell, ces programmes sont en fait une suite d'instructions qui sera interprétée par le shell.
Les entrailles du shell
Vous êtes maintenant munis d'une jolie batterie d'outils qui va entre autres vous permettre d'écrire tous vos scripts shell. Toutefois même en ayant récupéré la synthaxe de commandes vous continuez à subir des erreurs... Soit la commande ne vous retourne pas le résultat attendu soit le shell vous retourne des erreurs...
Ne vous êtes vous jamais posé cette question : est-ce que je mets des simples quotes, des doubles quotes ou des back quotes ?
Pour ne plus avoir à se poser ce genre de questions, il est essentiel de bien connaitre le fonctionnement interne du shell.
Les grandes étapes de l'interprétation d'une ligne de commandes
Pour mieux comprendre le résultat obtenu, il faut savoir que le shell lit plusieurs fois la ligne avant d'exécuter la commande.
Cette lecture se fait dans l'ordre suivant :
- substition de variables : le shell remplace les variables par leurs valeurs
- substitution de commandes : le shell remplace une variable par son contenu qui est le résultat d'une commande
- interprétation des pipes et des redirections
- expansion des noms de fichiers : interprétation des caractères spéciaux pour compléter un nom de fichier et/ou de répertoire
- exécution de la commande
On se rend donc compte qu'un caractère spécial peut être interprété par le shell avant d'être interprété au sein de la commande.
Exemple : le caractère "*" peut être interprété par le shell (remplace 0 ou n caractères pour compléter un nom de fichier) ou par une commande comme grep (répète de 0 à n fois le caractère précédent dans une chaîne de caractères). Toutefois, sans précision dans la synthaxe, et selon les étapes ci-dessus, le caractère sera d'abord interprété par le shell. D'où quelques surprises dans le résultat de la commande.
L'interprétation des caractères spéciaux
Pour choisir de faire interpréter les caractères spéciaux par le shell ou la commande, il existe 3 possibilités :
- utilisation des doubles quotes (ou guillemets en bon français) : lorsque la chaîne de caractères est écrite entre guillemets, tous les caractères spéciaux perdent leur signification sauf : $ \ et `` (simples quotes).
exemple :
bidule fic1 fic2 truc
* est un caractère spécial non protégé. Au premier passage du shell, il est donc interprété. Il signifie alors l'ensemble des fichiers du répertoire courant
*
* est protégé par les guillemets. Il n'est donc pas interprété par le shell comme caractère spécial et devient un caractère pour la commande echo. Dans le cadre de cette commande, * n'a aucune signification particulière, il est donc affiché à l'écran tel que.
- utilisation des simples quotes : lorsque la chaîne de caractères est écrite entre simples quotes, tous les caractères spéciaux sans exception perdent leur signification pour le shell. Ils seront donc éventuellement interprété par la commande passée.
exemple : recherche des lignes d'un script utilisant la variable PATH
[user@localhost user]$
Au premier passage, le shell interprète le $ comme introduisant une variable. Il remplace donc la variable par son contenu puis exécute la commande grep. Il ne trouve donc aucune ligne comportant les chemins référencés dans PATH.
echo $PATH
[user@localhost user]$
Le shell n'interprète pas le $ lors du premier passage car sa signification est annulée par les simples quotes. le $ est donc traité par la commande grep. Comme il n'a pas de signification particulière, il est interprété comme un caractère quelconque.
- annulation d'un caractère spécial avec \ : pour empêcher le shell d'interpréter un caractère spécial, il suffit de positionner un anti-slash devant le caractère spécial donné.
exemple : pour reprendre l'exemple précédent on aurait pu écrire aussi :
echo $PATH
[user@localhost user]$
Liste des caractères spéciaux
Ci-dessous la liste des caractères spéciaux du shell :
& |
processus en arrière-plan |
~ |
home directory |
; |
séparateur de commandes |
\ |
annulation d'un caractère spécial |
" |
doubles quotes : encadre une chaîne de caractères et annule la signification de $, \ et ' |
` |
back quotes : substitution de commandes |
'' |
simples quotes : encadre une chaîne de caractères et annule la signification de tous les caractères spéciaux |
# |
commentaire |
( ) |
exécution d'un shell fils |
[ ] |
test |
| |
pipe |
$ |
variable |
* |
remplace 0 ou n caractères |
! |
négation d'un test |
? |
remplace 1 caractère |
< > |
redirections entrée, sortie |
$0...$9 |
variables de position |
Appel des commandes
Autre élément à connaître pour ne pas avoir de surprise : à quel type de commande ai-je à faire ? on distingue des grands types de commande
- des commandes internes au shell : elles sont exécutées dans le même shell. si elles sont lancées à partir du shell père, il n'y aura pas création de shell fils
- des programmes binaires exécutables
- des fichiers de commande (shell-scripts)
- des alias
- des fonctions
La difficulté c'est que le shell interprète une commande en suivant un ordre très précis :
- le chemin de la commande comporte un /, il exécute donc la commande située dans ce chemin, il n'y a pas d'ambiguïté possible.
- le chemin de la commande ne comporte pas de /, il cherche la commande en suivant les étapes suivantes :
- consultation de la liste des alias
- consultations des fonctions chargées
- consultations des commandes internes du shell
- consultation de la variable PATH
Donc si vous tapez une commande quelleconque, un script shell par exemple, sans préciser le chemin, la consultation de la variable PATH n'arrive qu'en dernier. Attention si vous disposez d'un alias ou d'une fonction qui porte le même nom, il traitera l'alias ou la fonction.
Pour terminer 2 commandes utiles pour savoir à quel type de commande vous avez à faire :
- type nom_de_commande : permet de déterminer le type d'une commande (alias, fonction, commande interne...)
- which nom_de_commande : recherche le chemin de la commande dans PATH
exemples :
ls est un alias suivi pour /usr/bin/ls
[user@localhost user]$ type cd
cd est une commande prédéfinie du shell
[user@localhost user]$ which pwd
/usr/bin/pwd
Index des commandes
heu... bon là j'en ai marre, on verra ça plus tard ! :-)
Je place quand même ici 2 commandes qui peuvent être bien utiles :
cal : donne le calendrier du mois courant,
cal 12 1999 : donne le calendrier de décembre 1999,
cal 2000 : donne le calendrier des 12 mois de l'an 2000.
factor 12456988 : donne la décomposition en produit de facteurs premiers du nombre 12456988 (soit 2 x 2 x 17 x 183191) - c'est très mathématique, mais ultra rapide et puissant.
Pour terminer cet article, je vous renvoie vers ce petit manuel de référence, qui contient l'ensemble des commandes usuelles :
et aussi :
@ Retour à la rubrique Administration système
Copyright
© 02/11/1999 Jean-Christophe Cardot, Marc et Anne Nicolas
Ce document est publié sous licence Creative Commons Attribution, Partage à l'identique 4.0 : https://creativecommons.org/licenses/by-sa/4.0/ |