Professional Documents
Culture Documents
Sauf mention contraire, le contenu de cet ouvrage est publi sous la licence : Creative Commons BY-NC-SA 2.0 La copie de cet ouvrage est autorise sous rserve du respect des conditions de la licence Texte complet de la licence disponible sur : http://creativecommons.org/licenses/by-nc-sa/2.0/fr/ Simple IT 2010 - ISBN : 978-2-9535278-2-7
Avant-propos
inux, c'est d'abord l'histoire de passionns d'informatique dissmins sur la plante. On peut le comparer Windows et Mac OS : c'est un systme d'exploitation, l'outil de base dont a besoin votre ordinateur pour dmarrer et lancer des programmes. Tous ces passionns collaborent ensemble pour l'amliorer et le faire voluer, et ce sur leur temps libre. l'origine, il n'y avait d'ailleurs pas de grande entreprise derrire, comme Microsoft ou Apple. Les choses ont cependant bien chang depuis les dbuts de Linux dans les annes 1990 ! Alors qu'il s'agissait initialement d'un outil un peu complexe et obscur, il est progressivement devenu de plus en plus simple utiliser, au point dsormais de rivaliser de simplicit avec ses concurrents de toujours, Windows et Mac OS. On a vu natre plusieurs entreprises autour de l'cosystme Linux : Red Hat, Mandriva, Canonical. . . On le sait peu, mais Linux est aujourd'hui omniprsent sur le web : la plupart des serveurs qui font tourner les sites web fonctionnent sous Linux. On le retrouve aussi sur les tlphones mobiles : Android, le systme d'exploitation pour mobiles de Google, est fond sur Linux. Vous avez envie de dcouvrir le monde de Linux mais vous ne savez vraiment pas par o commencer ? Vous dbutez et vous avez peur que ce soit trop compliqu ? J'ai crit ce cours spcialement pour ceux qui, comme vous, cherchent un ouvrage pour dmarrer et comprendre comment Linux fonctionne. . . mais aussi pour vous montrer quel point cet univers peut tre passionnant et accessible tous ! :-)
CHAPITRE 0.
AV ANT-PROPOS
sa machine. Ce n'est pas un hasard si ce livre s'intitule Reprenez le contrle l'aide de Linux : en le lisant, vous allez progressivement avoir le sentiment de rellement matriser votre ordinateur. Je vous ferai part de mes conseils et de mon exprience de Linux sans prendre parti. Je ne cherche pas vous montrer que Linux est meilleur que Windows . Mon but est plutt de vous faire dcouvrir cet univers riche et de vous aider devenir autonomes. Le cours que vous allez dcouvrir a dj t lu plusieurs millions de fois en ligne sur le site que j'ai cr, le Site du Zro (www.siteduzero.com). Il a donc bnci de trs nombreuses relectures de la part de dbutants qui m'ont signal les points qui leur paraissaient obscurs, mais aussi d'experts qui m'ont aid en faire un cours enseignant de bonnes bases solides et vous donnant les bonnes habitudes. Ce livre est conu de faon assez peu conventionnelle : il dmarre vraiment partir de zro 1 et vous fait progressivement dcouvrir des notions plus complexes et plus pousses 2 . Il couvre donc un large spectre de ce qu'il faut connatre pour matriser Linux.
ii
5. Automatisez vos tches avec des scripts Bash : nous y apprendrons automatiser les tches courantes grce aux scripts Bash pour viter d'avoir rpter les mmes commandes tout le temps. Cette dernire partie plaira tout particulirement ceux qui s'intressent la programmation !
Un formulaire vous invite rentrer votre code web. Faites un premier essai avec le code ci-dessous : Code web : 123456 Ces codes web ont plusieurs intrts : ils vous redirigent vers les sites web prsents tout au long du cours, ous permettant ainsi d'obtenir les logiciels dans leur toute dernire version ; ils vous permettent de tlcharger les codes sources des scripts Bash inclus dans ce livre, ce qui vous vitera d'avoir recopier certains codes un peu longs. Ce systme de redirection nous permet de tenir jour le livre que vous tenez entre vos mains sans que vous ayez besoin d'acheter systmatiquement chaque nouvelle dition.
3. Vous pouvez aussi utiliser le formulaire de recherche du Site du Zro, section Code web .
iii
CHAPITRE 0.
AV ANT-PROPOS
Si un site web change d'adresse, nous modierons la redirection mais le code web utiliser restera le mme. Si un site web disparat, nous vous redirigerons vers une page du Site du Zro expliquant ce qui s'est pass et vous proposant une alternative. Si une capture d'cran n'est plus jour, nous vous indiquerons ce qui a chang et comment procder. En clair, c'est un moyen de nous assurer de la prennit de cet ouvrage sans que vous ayez faire quoi que ce soit !
Remerciements
Je tiens remercier toutes les personnes qui m'ont aid et soutenu dans la ralisation de ce livre. Mes parents, qui me font conance et continuent de suivre attentivement mes projets. lodie, qui est toujours l pour me donner la dose de courage dont j'ai besoin. Pierre Dubuc, qui s'est mis en quatre pour que ce livre soit publi dans les meilleures conditions possibles. Nos infographistes, Fan Jiyong (couverture du livre) et Yannick Piault (illustrations des chapitres), qui nous ont encore fait un superbe travail d'illustration. L'quipe des zCorrecteurs, qui fait des merveilles pour corriger les fautes et amliorer l'expression de cet ouvrage. Merci tout particulirement Philippe Lutun (ptipilou), Martin Wetterwald (DJ Fox), Stphanie Noardo (Poulpette), Maxence Cordiez (Ziame), Charles Duprey (Barbatos) et Julian Esprat (Savageman). L'quipe de Simple IT qui fait un travail formidable pour amliorer le Site du Zro, et tous nos visiteurs qui nous font conance ! Merci, merci, merci !
iv
Sommaire
Avant-propos
la dcouverte de Linux avec Ubuntu . . . Qu'allez-vous apprendre en lisant ce livre ? . Comment lire ce livre ? . . . . . . . . . . . . Ce livre est issu du Site du Zro . . . . . . Remerciements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .
i
i ii iii iv iv
1
3
17
29
SOMMAIRE
41
42 46 49 56
63
Bienvenue sur le bureau Gnome . . . . . . . . . . . . . . . . . . . . . . . . . . 64 Nautilus, l'explorateur de chiers . . . . . . . . . . . . . . . . . . . . . . . . . 67 Gestion des programmes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70
75
76 76 79 83
87
88 90 96 101
105
107
108 110 115 116
123
L'invite de commandes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124 Commandes et paramtres . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126 Retrouver une commande . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 130 vi
SOMMAIRE
135
136 138 141 146 151
155
cat & less : acher un chier . . . . . . . . . . . . . . . . . . . . . . . . . . 156 head & tail : acher le dbut et la n d'un chier . . . . . . . . . . . . . . . 162 touch & mkdir : crer des chiers et dossiers . . . . . . . . . . . . . . . . . . 165 cp & mv : copier et dplacer un chier . . . . . . . . . . . . . . . . . . . . . . 167 rm : supprimer des chiers et dossiers . . . . . . . . . . . . . . . . . . . . . . . 170 ln : crer des liens entre chiers . . . . . . . . . . . . . . . . . . . . . . . . . . 173
179
sudo : excuter une commande en root . . . . . . . . . . . . . . . . . . . . . . 180 adduser, deluser : gestion des utilisateurs . . . . . . . . . . . . . . . . . . . 182 addgroup, delgroup : gestion des groupes . . . . . . . . . . . . . . . . . . . . 185 chown, chgrp : gestion des propritaires d'un chier . . . . . . . . . . . . . . 187 chmod : modier les droits d'accs . . . . . . . . . . . . . . . . . . . . . . . . 189
195
Premiers pas avec Nano . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196 Congurer Nano avec .nanorc . . . . . . . . . . . . . . . . . . . . . . . . . . 203 Congurer sa console avec .bashrc . . . . . . . . . . . . . . . . . . . . . . . . 207
213
214 215 221 222 224 225 vii
SOMMAIRE
apt-get autoremove : supprimer un paquet . . . . . . . . . . . . . . . . . . 228 apt-get upgrade : mettre jour tous les paquets . . . . . . . . . . . . . . . 229
231
Comprendre le SYNOPSIS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235 apropos : trouver une commande . . . . . . . . . . . . . . . . . . . . . . . . . 242 D'autres faons de lire le manuel . . . . . . . . . . . . . . . . . . . . . . . . . 243
247
locate : une recherche rapide . . . . . . . . . . . . . . . . . . . . . . . . . . . 248 find : une recherche approfondie . . . . . . . . . . . . . . . . . . . . . . . . . 249
257
259
grep : ltrer des donnes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 260 sort : trier les lignes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 265 wc : compter le nombre de lignes . . . . . . . . . . . . . . . . . . . . . . . . . 268 uniq : supprimer les doublons . . . . . . . . . . . . . . . . . . . . . . . . . . . 270 cut : couper une partie du chier . . . . . . . . . . . . . . . . . . . . . . . . . 271
277
> et >> : rediriger le rsultat dans un chier . . . . . . . . . . . . . . . . . . . 278 2>, 2>> et 2>&1 : rediriger les erreurs . . . . . . . . . . . . . . . . . . . . . . . 282 < et << : lire depuis un chier ou le clavier . . . . . . . . . . . . . . . . . . . . 285 | : chaner les commandes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 288
295
w : qui fait quoi ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 296 ps & top : lister les processus . . . . . . . . . . . . . . . . . . . . . . . . . . . 299 Ctrl + C & kill : arrter un processus . . . . . . . . . . . . . . . . . . . . . 305 halt & reboot : arrter et redmarrer l'ordinateur . . . . . . . . . . . . . . . 308
311
SOMMAIRE
325
date : rgler l'heure . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 326 at : excuter une commande plus tard . . . . . . . . . . . . . . . . . . . . . . 327 sleep : faire une pause . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 330 crontab : excuter une commande rgulirement . . . . . . . . . . . . . . . . 331
337
339
tar : assembler des chiers dans une archive . . . . . . . . . . . . . . . . . . . 340 gzip & bzip2 : compresser une archive . . . . . . . . . . . . . . . . . . . . . 343 unzip & unrar : dcompresser les .zip et .rar . . . . . . . . . . . . . . . . . 347
351
352 353 356 364 371
385
wget : tlchargement de chiers . . . . . . . . . . . . . . . . . . . . . . . . . 386 scp : copier des chiers sur le rseau . . . . . . . . . . . . . . . . . . . . . . . 388 ftp & sftp : transfrer des chiers . . . . . . . . . . . . . . . . . . . . . . . . 390 rsync : synchroniser des chiers pour une sauvegarde . . . . . . . . . . . . . 394
401
host & whois : qui tes-vous ? . . . . . . . . . . . . . . . . . . . . . . . . . . 402 ifconfig & netstat : grer et analyser le trac rseau . . . . . . . . . . . . 406 iptables : le pare-feu de rfrence . . . . . . . . . . . . . . . . . . . . . . . . 412
421
ix
SOMMAIRE
Essayez d'abord de trouver un paquet .deb . . . . . . . . . . . . . . . . . . . 422 Quand il n'y a pas d'autre solution : la compilation . . . . . . . . . . . . . . . 423
429
431
432 434 437 441 444 447
453
Qu'est-ce qu'un shell ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 454 Notre premier script . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 458 Excuter le script bash . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 460
463
464 465 468 471 472 473 475
30 Les conditions
477
31 Les boucles
491
while : boucler tant que . . . . . . . . . . . . . . . . . . . . . . . . . . . 492 for : boucler sur une liste de valeurs . . . . . . . . . . . . . . . . . . . . . . . 493
SOMMAIRE
497
xi
SOMMAIRE
xii
Premire partie
Dcouvrir et installer Linux
Chapitre
1
Dicult :
inux ? Dicile de ne pas en entendre parler aujourd'hui. moins d'tre rests enferms dans un bunker antinuclaire coup de tout lien avec le reste du monde, vous avez forcment rencontr ce mot quelque part sur Internet ou au cours d'une conversation entre amis. Ce n'est pas tonnant : Linux est partout. Sans Linux, beaucoup de sites web et de programmes n'existeraient pas aujourd'hui.
C'est la question laquelle ce premier chapitre va rpondre, pas de panique. Nous n'allons rien installer pour le moment, juste dcouvrir ce que c'est et comment nous en sommes arrivs l. . . parce que c'est vraiment important ! Alors installez-vous confortablement et commenons par le commencement. ;-)
CHAPITRE 1.
Un systme d'exploitation
Est-ce que vous avez dj entendu parler de Windows ? 1 Aujourd'hui, la quasi-totalit des PC (si ce n'est plus !) est livre avec Windows . Mais savez-vous ce que cela signie ?
Oui, moi je sais ! a signie qu'on voit marqu Windows au dmarrage de l'ordinateur ! Non. . . ce n'est pas a ?
Oui allez, disons que c'est un bon dbut. En eet, l'une des premires choses que vous voyez lorsque vous allumez votre ordinateur est un cran comme celui de la gure 1.1.
UN SYSTME D'EXPLOITATION
Pourquoi ? Parce qu'il dpend du matriel dont est constitu votre ordinateur. C'est en eet la carte mre qui ache l'cran de boot. La carte mre est le composant fondamental de tout ordinateur, c'est elle qui fait travailler le processeur, les disques durs, le lecteur de CD-ROM, etc. On a donc dans l'ordre : 1. cran de boot ; 2. dmarrage de Windows. C'est seulement une fois que Windows est charg que vous pouvez enn utiliser vos programmes : jeux, Internet, logiciels de dessin, de mail, de musique. . .
Mais pourquoi faut-il que Windows se charge d'abord ? Pourquoi ne pourraiton pas lancer des jeux ds le dmarrage de l'ordinateur ?
Parce que. . . votre ordinateur a besoin d'une sorte de superlogiciel qui soit le chef d'orchestre. C'est lui qui doit grer la mmoire de votre ordinateur, la rpartir entre tous les programmes. Il fait le lien entre votre matriel (carte graphique, mmoire, imprimante) et vos logiciels. Et c'est un sacr boulot, croyez-moi ! ;-) Ce superlogiciel s'appelle le systme d'exploitation. Windows est donc un systme d'exploitation.
Un systme d'exploitation se dit Operating System en anglais, que l'on abrge en OS . J'utiliserai souvent cette abrviation par la suite, ne soyez donc pas surpris !
Si on rsume l'ordre des choses, au nal nous avons donc cela : 1. cran de boot ; 2. dmarrage du systme d'exploitation (Windows) ; 3. lancement des programmes (jeux, Internet, mail. . .). Si vous prfrez les schmas 2 , reportez-vous la gure 1.2.
CHAPITRE 1.
le moment est le principe de base de Linux : c'est vous qui contrlez votre ordinateur. Ce n'est donc pas par hasard si ce cours s'appelle Reprenez le contrle l'aide de Linux ! . Vous allez enn comprendre ce que vous faites et donc mieux apprhender le fonctionnement de l'informatique !
Peut-on faire cohabiter deux OS sur son ordinateur ? Je n'ai pas envie de supprimer Windows pour le remplacer par Linux !
Beaucoup de gens croient qu'il faut faire un choix : Linux ou Windows. Rien n'est plus faux : vous pouvez trs bien avoir deux OS (ou plus !) installs sur votre ordinateur. Dans ce cas, juste aprs l'cran de boot, vous aurez un programme appel Boot Loader qui s'achera pour que vous puissiez faire votre choix. Le boot loader dont nous parlerons ici porte le doux nom de GRUB. Celui-ci vous proposera de choisir entre Windows et Linux chaque dmarrage de l'ordinateur. GRUB lancera l'OS par dfaut si vous ne faites pas de choix avant quelques secondes. C'est vous qui choisissez l'OS par dfaut, bien entendu ; on ne vous impose rien. Le schma du dmarrage de l'ordinateur change donc un peu, comme le montre la gure 1.3. Comme vous pouvez dj le voir sur ce schma, lorsque vous tes sous Linux, vous utilisez des programmes faits pour Linux et non pas les programmes de Windows. En eet, les programmes Windows ne fonctionnent pas sous Linux et inversement. 6
UN SYSTME D'EXPLOITATION
CHAPITRE 1.
Sachez quand mme qu'il est possible de faire tourner des programmes Windows depuis Linux l'aide d'un programme appel wine. Toutefois, mme si cela fonctionne bien la plupart du temps, il est davantage prfrable d'utiliser des programmes faits pour Linux une fois que vous utilisez cet OS car ils tournent plus rapidement.
Vous devez dj vous dire : Ae, si je ne peux plus utiliser les programmes de Windows auxquels je suis habitu, je ne vais pas m'en sortir . Pourtant, il ne faut pas longtemps pour s'adapter 3 et les programmes sous Linux ont d'normes avantages : ils sont gratuits : vous verrez que sous Linux, presque tous les programmes sont gratuits ; les logiciels sont souvent mis jour et ce toujours gratuitement ! Vous verrez donc frquemment vos logiciels prfrs voluer et n'aurez pas payer trois cents euros pour vous mettre jour ! certains de ces logiciels sont meilleurs que ceux que l'on trouve sous Windows. D'ailleurs, certains n'existent mme pas sous Windows ! Vous dcouvrirez de nouvelles fonctionnalits et nirez par gagner du temps tout en utilisant plus ecacement votre ordinateur.
Mais pourquoi les programmes sont-ils gratuits ? Ce n'est pas compltement suicidaire nancirement ?
C'est justement ce que je vais vous expliquer maintenant.
La naissance de Linux
Voyons les choses en face. Windows cote environ 200 ou 300 euros. Linux est gratuit, soit 0 euro TTC. On ne peut pas s'empcher de se dire : Mais si c'est gratuit, c'est que cela doit tre quelque chose de vite fait et de moindre qualit ! . Grossire erreur. Si Linux est gratuit (comme quasiment tous ses logiciels), il y a des raisons ; pour comprendre, il faut remonter 1984.
L'informatique en 1984
Nous sommes donc en 1984. cette poque, l'informatique n'est pas trs dveloppe. Microsoft vient de sortir son premier OS : MS-DOS. Mais ce dernier est encore loin d'tre abouti.
3. Deux ou trois jours susent, voire mme une soire si vous tes curieux !
LA NAISSANCE DE LINUX
Si vous avez utilis les premires versions de Windows, vous avez forcment entendu parler de MS-DOS (gure 1.4). En eet, toutes les versions de Windows 95 Windows Me taient bases sur MS-DOS (MS-DOS se lanait au dmarrage juste avant Windows). Ce n'est que depuis Windows XP que MS-DOS a compltement disparu. Aujourd'hui, il n'est plus dvelopp.
Le projet GNU
C'est justement cette poque, en 1984, que Richard Stallman cra le projet GNU. Richard Stallman tait alors chercheur en intelligence articielle au MIT. Il voulait crer un nouveau systme d'exploitation fonctionnant comme Unix (les commandes restant les mmes). 9
CHAPITRE 1.
Bon savoir : Mac OS X est lui aussi bas sur Unix. En revanche, MS-DOS et Windows sont compltement part.
GNU est un systme d'exploitation libre
GNU ne devait pas seulement tre un OS gratuit ; il devait galement tre libre .
Quelle dirence ?
Un programme libre est un programme dont on peut avoir le code source, c'est--dire la recette de fabrication . Au contraire, Windows est un OS propritaire dont le code source est conserv par Microsoft. Imaginez que c'est un peu comme le CocaCola : personne ne connat la recette de fabrication 4 . On ne peut donc pas le modier
4. Il y a bien des gens qui essaient de l'imiter, mais bon. . .
10
LA NAISSANCE DE LINUX
ou regarder comment il fonctionne l'intrieur. Un programme libre est donc la plupart du temps un programme gratuit. Mais c'est aussi un programme qu'on a le droit de copier, modier, redistribuer. C'est une vritable idologie en informatique : des gens pensent qu'il vaut mieux donner le code source des programmes que l'on cre car cela permet le partage des connaissances et aide l'informatique voluer plus vite. Le slogan du monde du Libre pourrait tre : L'union fait la force .
On dit aussi souvent que le programme est Open Source , car son code source est ouvert ; tout le monde peut le voir. Il existe quelques lgres diffrences entre un programme Open Source et un programme libre , mais nous n'entrerons pas dans les dtails ici.
CHAPITRE 1.
Thoriquement, on doit donc parler de GNU/Linux. C'est toutefois un peu dicile crire et prononcer, et par abus de langage, on dit souvent juste Linux . C'est donc pour cela que je continuerai parler de Linux dans la suite du livre, mme si le nom politiquement correct est GNU/Linux puisqu'il s'agit de la fusion de deux projets complmentaires.
Les programmes Linux n'utilisent pas du tout le mme code source que ceux d'Unix (celui-ci tait d'ailleurs propritaire, donc priv). Ils ont t compltement rcrits mais fonctionnent de la mme manire.
Si je vous ai racont tout cela c'est parce que j'estime que connatre l'origine de Linux est important. Cela vous permettra de comprendre bon nombre de choses par la suite. 12
13
CHAPITRE 1.
La distribution Debian
Nous, nous allons nous concentrer sur la distribution Debian (gure 1.9).
Figure 1.10 La carte des dveloppeurs de Debian. Chaque point reprsente une personne participant la cration de Debian.
14
Un autre gros avantage de Debian est le gestionnaire de paquets apt-get. C'est un programme qui gre tous les logiciels installs et qui vous permet de les dsinstaller en un rien de temps. D'autre part, tous les logiciels sont centraliss en un mme endroit, ce qui fait que vous n'avez pas parcourir tout le Web pour retrouver un programme. En fait, vous avez juste indiquer le nom du logiciel que vous dsirez : Debian ira le tlcharger et l'installer pour vous. C'est extrmement simple d'utilisation, je vous montrerai cela ! Debian a tellement de succs que de nombreuses distributions sont bases sur Debian : Knoppix ; Skolelinux ; Ubuntu ; ... Ce sont donc des. . . distributions de distributions. :-) O.K. : vous trouvez que ce n'est pas clair. Trs bien, trs bien, je ne vais pas le prendre mal, je vais vous proposer. . . un nouveau schma (gure 1.11) !
CHAPITRE 1.
En rsum
Le systme d'exploitation est l'outil qui fait le lien entre votre machine et vos programmes. Windows, Mac OS et Linux sont les systmes d'exploitation les plus connus. Linux a la particularit d'tre libre, c'est--dire que son code source (sa recette de fabrication) est ouvert : tout le monde peut le consulter. Par opposition, le code source qui a permis de concevoir Windows et Mac OS est ferm, on dit que ce sont des systmes d'exploitation propritaires. Il existe de nombreuses variantes de Linux, que l'on appelle distributions. Ubuntu est une des distributions les plus populaires l'heure actuelle. C'est celle que nous utiliserons tout au long de cet ouvrage. Il s'agit d'un driv de la distribution Debian.
16
Chapitre
2
Dicult :
e premier chapitre vous aura permis, je l'espre, de vous mettre un peu dans le bain du monde de Linux. Nous avons vu ce qu'est Linux, comment est n ce dernier et ce que sont les distributions. Je vous ai dit en particulier que, sous Linux, nous avons normment de choix. Il existe en eet de trs nombreuses distributions qui proposent des versions direntes de Linux, fort heureusement toutes compatibles entre elles. Dans ce livre, j'ai choisi de vous prsenter Ubuntu car c'est une distribution trs populaire et facile utiliser. Comme promis, c'est dans ce chapitre que nous passons la pratique. Nous allons dans un premier temps dcouvrir ce que sont les gestionnaires de bureau et choisir en consquence la version d'Ubuntu qui nous convient le mieux (eh oui, on va encore devoir faire un choix !).
17
CHAPITRE 2.
En mode console
Le mode console est un mode qui a tendance faire peur aux petits nouveaux ; et pour cause, il n'a pas une tte trs accueillante : jugez plutt (gure 2.1). En console, le fond est gnralement noir (mais ce n'est pas une rgle). Il est cependant possible d'utiliser de la couleur. Autre point important : en console, pas de souris. Tout se fait au clavier.
Figure 2.1 Le mode console. Oui oui, il s'agit bien d'un Linux du XXIe sicle !
est toujours utilise aujourd'hui par les linuxiens dont vous ferez bientt partie. Comment puis-je tre aussi sr de moi ?. . . Parce que je compte bien vous en expliquer le fonctionnement ! ;-) 1
En mode graphique
Le mode graphique semble beaucoup plus accueillant pour quelqu'un venant de Windows. En fait, cela ressemble un peu ce dernier : il y a des fentres et on clique sur des croix pour les fermer. Standard, quoi. ;-) Le truc. . . c'est qu'il y a plusieurs modes graphiques. Tous les modes graphiques sont bass sur un programme appel X (voil un nom court et facile retenir). X est en fait la brique de base du mode graphique sous Linux. Par-dessus X vient se greer un programme appel le gestionnaire de bureau. Le rle du gestionnaire de bureau est de grer les fentres, leur apparence, leurs options, etc.
Le concept de gestionnaire de bureau n'existant pas sous Windows, il s'agit donc de quelque chose nouveau pour vous. Certes, sous Windows on peut changer l'apparence (le skin ), mais cela s'arrte l. Le bureau reste le mme, il y a toujours une barre des tches avec le menu Dmarrer, toujours un Poste de Travail, etc. Sous Linux en revanche le fonctionnement peut radicalement changer d'un gestionnaire de bureau l'autre !
1. En partant de zro bien sr, ce n'est pas un Livre du Zro pour rien. ;-)
19
CHAPITRE 2.
20
CHAPITRE 2.
22
change. Quand on parle d'Ubuntu, on fait donc gnralement rfrence toutes les versions d'Ubuntu la fois.
Le choix du gestionnaire de bureau n'est pas dnitif. On peut sans problme avoir plusieurs gestionnaires de bureau installs la fois. Il vous faudra alors choisir au dmarrage, lorsque l'on vous demande votre identiant et votre mot de passe, le gestionnaire de bureau que vous souhaitez utiliser. Vous pourrez donc tester et installer d'autres gestionnaires de bureau par la suite. Sachez d'ailleurs qu'il en existe des moins rpandus et qui permettent d'avoir un bureau vraiment trs dirent de Windows.
Enn, une information importante retenir : tous ces gestionnaires de bureau sont compatibles entre eux. Les programmes fonctionnent donc tous quel que soit le gestionnaire de bureau que vous utilisez. ;-)
CHAPITRE 2.
Figure 2.6 La console reste la mme quel que soit le gestionnaire de bureau
autre ; par contre, l'aspect graphique peut radicalement changer selon le gestionnaire de bureau que l'on choisit : KDE, Gnome, XFCE, etc.
Tlcharger et graver le CD
Intressons-nous maintenant au concret : comment obtenir Ubuntu sur CD pour le tester et peut-tre l'installer ? Vous avez deux solutions : vous pouvez tlcharger Ubuntu vous-mmes. . . ; . . . ou bien commander des CD par la poste. Nous allons commencer par voir comment tlcharger Ubuntu.
1/ Rcuprer l'ISO
Linux se tlcharge sous la forme d'un gros chier .iso d'environ 700 Mo. Ce chier correspond l'image d'un CD et vous permet donc de graver un CD complet de Linux. La premire tape consiste rcuprer le chier ISO. L, tout dpend si vous avez choisi Ubuntu, Kubuntu ou Xubuntu, car ce n'est pas le mme ISO. Utilisez le code web 3 correspondant la distribution que vous souhaitez obtenir. Si vous hsitez, je vous conseille de prendre Ubuntu.
3. Pour savoir comment utiliser ces codes web, je vous invite consulter l'avant-propos au dbut de cet ouvrage, page iii.
24
TLCHARGER ET GRAVER LE CD
Tlcharger Xubuntu Code web : 821320 Sur la page, cliquez tout simplement sur le lien de tlchargement. Vous allez rcuprer un chier .iso.
2/ Graver le CD
Il vous faut maintenant graver le gros chier .iso que vous venez de tlcharger.
Sous Windows 7
Si vous avez Windows 7, un outil de gravure d'images disque .iso est dj inclus. Il vous sut de double-cliquer sur le chier .iso, ce qui aura pour eet d'ouvrir la fentre de la gure 2.7.
CHAPITRE 2.
Tlcharger CDBurnerXP Code web : 767566 Insrez un CD-R (CD vierge) dans votre graveur. Lancez ensuite le logiciel CDBurnerXP Pro et, lors du dmarrage, cliquez sur Crer un CD/DVD de donnes , comme vous le montre la gure 2.8.
COMMANDER UN CD
Eh bien voil, ce n'tait pas bien compliqu. Vous avez maintenant un CD d'Ubuntu ambant neuf, gratuit, lgal, qui n'attend que d'tre essay. Nous verrons justement dans le chapitre suivant comment tester Linux. Mais avant cela, nous allons voir une autre manire d'obtenir un CD d'Ubuntu. . .
Commander un CD
Une autre solution consiste commander un CD par la poste grce au service ShipIt d'Ubuntu. Commander un CD Code web : 202490 Il faut crer un compte pour commander, mais rassurez-vous, on ne vous spammera pas. Par ailleurs, l'envoi de CD est gratuit.
Comment peuvent-ils faire cela ? C'est bien beau le libre, mais ce n'est pas viable conomiquement !
En eet : Canonical, la socit qui dite Ubuntu, perd de l'argent lorsque vous commandez des CD par la poste. C'est un choix dlibr de leur part pour promouvoir Ubuntu, mais ils insistent sur le fait qu'il est prfrable de tlcharger un ISO et ils vous invitent faire un don.
Bon savoir : ShipIt, c'est gratuit. . . mais c'est lent. Le CD peut mettre plusieurs semaines pour arriver. Mon conseil : si vous le pouvez, tlchargez Ubuntu, cela ira plus vite.
En rsum
Linux peut tre utilis de deux faons direntes : en mode console ou en mode graphique. Le mode console est puissant mais plus dlicat apprivoiser. Les dbutants prfrent l'viter au dbut. Le mode graphique est similaire ce que vous connaissez sous Windows et Mac OS : on y manipule des fentres avec une souris. Il existe plusieurs variantes du mode graphique que l'on appelle gestionnaires de bureau : Gnome, KDE, XFCE... Pour obtenir Ubuntu, il sut de tlcharger gratuitement une image de disque (format .iso) et de la graver sur un CD.
27
CHAPITRE 2.
28
Chapitre
3
Dicult :
ous y voici enn. Dans ce chapitre, vous allez peut-tre pour la premire fois de votre vie voir quoi ressemble Linux sur votre ordinateur et dcouvrir qu'en fait. . . c'est beaucoup plus simple que vous ne le pensiez. Saviez-vous qu'on peut tester Linux sur son ordinateur sans rien installer sur son disque dur ? On va justement voir maintenant comment faire cela. Ensuite, je vous montrerai comment installer Linux sur votre disque dur si vous tes dcids. ;-)
29
CHAPITRE 3.
Un autre gros avantage de cette mthode est que vous pourrez ensuite dsinstaller Ubuntu le plus simplement du monde en allant dans. . . Ajout / Suppression de programmes du panneau de conguration de Windows !
Cette mthode a toutefois quelques dfauts. Ubuntu sera un peu moins performant (car il sera install dans Windows) et ncessitera plus de mmoire vive (512 Mo). Dans la mesure du possible, je vous conseille d'installer Ubuntu en utilisant la vraie mthode classique que nous allons voir ci-dessous.
CHAPITRE 3.
Si vous n'avez pas eu de problme et que vous avez vu l'cran d'accueil d'Ubuntu ds le dbut, vous pouvez directement sauter l'tape suivante.
33
CHAPITRE 3.
INSTALLER UBUNTU
vous tes dj certains de vouloir installer Ubuntu. Par la suite, je vais supposer que vous avez fait le premier choix 2 . Ubuntu va alors se charger partir du CD dans la mmoire vive. En eet, dans ce mode de test appel Live CD , Linux ne touche pas votre disque dur. Aucun risque d'altrer Windows, tout est fait dans la mmoire vive (et entre nous, c'est une sacre prouesse technique !).
En mode Live CD, tout est charg depuis le CD. . . or, un CD est beaucoup plus lent qu'un disque dur ! Si le chargement de Linux s'ternise, ne paniquez pas, c'est tout fait normal : la lecture depuis le CD prend beaucoup de temps. Rassurez-vous : une fois Linux install sur le disque dur, le chargement sera bien plus rapide que cela. ;-)
Une fois le chargement eectu, vous allez rapidement vous retrouver sur le gestionnaire de bureau que vous avez choisi. Si, comme moi, vous avez opt pour Ubuntu, vous serez donc sous Gnome. Le bureau de Gnome ressemble la gure 3.7 (il peut lgrement varier en fonction de votre version d'Ubuntu). Alors, qu'en dites-vous ? Ce n'tait pas franchement la mer boire ! Retenez bien : tout ce que vous voyez l a t charg dans votre mmoire vive. Ubuntu n'a pas touch votre disque dur. Vous pouvez donc tester Linux en toute scurit. N'hsitez pas parcourir les menus et vous familiariser un peu avec l'environnement de bureau que vous avez choisi.
Je dtaillerai le fonctionnement des gestionnaires de bureau KDE et Gnome dans les prochains chapitres. Pour le moment, je vous laisse le soin de dcouvrir un peu par vous-mmes, j'estime que c'est important.
Installer Ubuntu
Alors, vous avez fait un petit tour dans les programmes fournis avec Ubuntu ? Sachez que selon la version que vous avez prise (Ubuntu, Kubuntu ou Xubuntu), les programmes installs par dfaut seront dirents. En eet, certains programmes sont la base destins KDE, mais fonctionnent aussi sans problme sur Gnome. Inversement : certains programmes sont destins, la base, Gnome, mais on peut trs bien les utiliser sous KDE (c'est le cas de Firefox, par exemple). Il n'y a donc pas d'incompatibilit entre les gestionnaires de bureau, mais on prfre gnralement installer au dpart les programmes prvus pour KDE sur KDE, histoire d'tre. . . logique. Allez, je vous sens chauds pour une petite installation, l. On y va ?
2. Celui que tous les dbutants seraient tents de faire !
35
CHAPITRE 3.
36
INSTALLER UBUNTU
Attention : mme si l'installation est trs dtaille et scurise, il y a toujours un petit risque que vous installiez par-dessus Windows. Dans tous les cas, faites une sauvegarde de vos chiers les plus importants avant de commencer l'installation, sur CD ou cl USB par exemple. Pas de panique, tout va bien se passer, mais en gnral deux protections valent mieux qu'une.
CHAPITRE 3.
INSTALLER UBUNTU
que vous habitiez dans un pays qui possde un clavier dirent, comme la Suisse ou le Canada. Pour les Franais, le bon type de clavier est normalement slectionn d'oce. Vous pouvez tester votre clavier dans le petit cadre de texte en bas de la fentre. Essayez de taper des symboles spciaux comme , , , , etc. Si ces symboles s'achent sans problme, c'est que vous avez indiqu le bon type de clavier.
En rsum
Il est possible d'installer Ubuntu directement depuis Windows, mais la manipulation classique consiste plutt redmarrer l'ordinateur avec le CD d'Ubuntu dans le lecteur. La premire fois, Ubuntu se charge directement sur le CD, en mode Live CD. Votre disque dur n'est pas modi et vous pouvez tester Ubuntu tranquillement. Si vous tes dcids, il sut de lancer le programme d'installation depuis Ubuntu et de suivre les tapes.
39
CHAPITRE 3.
40
Chapitre
4
Dicult :
'tape du partitionnement est probablement l'une des plus importantes de l'installation de Linux. Elle consiste dcouper votre disque en plusieurs parties an, par exemple, de ne pas mlanger Linux et Windows (a ferait dsordre). Avant de partitionner votre disque, nous allons dcouvrir ce qu'est le partitionnement et quoi cela sert. Ensuite, nous verrons comment eectuer le partitionnement l'aide de l'outil propos lors de l'installation d'Ubuntu. Soyez attentifs, car il faut que cette tape soit ralise au mieux. Il est en eet dlicat de faire marche arrire une fois le partitionnement eectu.
41
CHAPITRE 4.
Bien que les risques soient minimes si vous suivez pas pas mes instructions, je vous recommande quand mme de faire une sauvegarde de vos donnes importantes sous Windows avant de commencer ce chapitre. Le partitionnement, si vous l'eectuez mal, pourrait aecter la partition Windows. Pas de panique, tout sera expliqu, mais on n'est jamais trop prudent non plus.
L'importance de la dfragmentation
Avant d'aller plus loin, il est trs vivement conseill d'eectuer une dfragmentation. C'est une opration qui consiste en gros mieux organiser les chiers sur votre disque dur, les rassembler pour viter qu'ils ne soient parpills. On ne dirait pas comme a, mais vos chiers sont parfois placs un peu n'importe comment la surface de votre disque dur ! Voici un petit schma sur la gure 4.3 pour bien comprendre dans quel tat est votre disque.
CHAPITRE 4.
Sous Windows XP
La fentre de la gure 4.5 s'ouvre. Slectionnez le disque dur que vous voulez dfragmenter (celui qui contient Windows, gnralement C:) et cliquez sur le bouton Dfragmenter . Vous pouvez sortir prendre l'air, parce que la dfragmentation peut prendre un moment 1 . Pendant la dfragmentation, l'avancement est indiqu en bas de la fentre (gure 4.6).
Sous Windows 7
La fentre est sensiblement dirente (gure 4.7), mais le principe est le mme. Il sut de slectionner le disque dfragmenter (si vous en avez plusieurs). Il est conseill de tous les dfragmenter. Cliquez ensuite sur Dfragmenter le disque . N'teignez pas votre PC pendant la procdure et attendez sagement. Idalement, vitez
1. Plusieurs heures si vous n'en avez jamais fait.
44
CHAPITRE 4.
46
Figure 4.10 Windows, Linux et vos documents ont chacun leur espace
Ainsi, Linux et Windows pourraient s'changer vos chiers (photos, documents texte, etc.) sans interfrer l'un avec l'autre. Autre intrt de cette technique : si par hasard vous deviez rinstaller Linux ou Windows, vous ne perdriez pas vos documents car seules les partitions Linux ou Windows seraient formates ! En quelque sorte, mettre 47
CHAPITRE 4.
vos documents dans une partition spare, c'est les mettre l'abri.
Systmes de chiers Microsoft (DOS et Windows) FAT 16 : un trs vieux systme de chiers, capable de grer jusqu' 4 Go de donnes.
Il est donc impossible de faire une partition en FAT 16 de plus de 4 Go. Il tait trs utilis l'poque du DOS et aux dbuts de Windows 95. FAT 32 : une volution du FAT 16, qui pousse la limite de taille 2 To (2 000 Go). Le FAT 16 et le FAT 32 ont la particularit de beaucoup fragmenter les chiers, d'o la ncessit de dfragmenter rgulirement, sinon on prend le risque de voir son disque ressembler un vritable champ de bataille. NTFS : apparu avec Windows NT, puis rutilis par Windows XP, il permet de crer des partitions d'une taille allant jusqu' 16 Eo (16 Exaoctets, soit 16 000 000 000 de Gigaoctets). Mais ce n'est pas tant la taille maximale qui est intressante (on en est franchement loin) que les avantages que le NTFS procure ct. Contrairement au FAT 32, c'est un systme de chiers journalis qui rcupre beaucoup mieux les donnes en cas de crash du disque. D'autre part, on peut donner des droits sur certains chiers, les crypter, les compresser, etc. Enn, les chiers sont censs moins se fragmenter. . . cependant, ils se fragmentent toujours.
Systmes de chiers Linux ext2 : c'est le systme de chiers qui a longtemps t utilis sous Linux. Il a t
dvelopp par un franais (Rmy Card) et prsente la particularit de trs peu se fragmenter. Ainsi, sous Linux et depuis longtemps, il n'y a pas besoin de faire de dfragmentation. ext3 : l'ext3 est trs proche de l'ext2, une dirence majeure prs : la journalisation. En eet, ext2 n'tait pas journalis et en cas de crash du disque, on risquait plus facilement une perte de donnes. Ce n'est plus le cas avec l'ext3. noter que l'ext2 et l'ext3 sont parfaitement compatibles entre eux, dans un sens comme dans l'autre. ext4 : une amlioration de l'ext3, relativement rcente, qui amliore la prise en charge des gros disques durs et diminue les problmes de fragmentation des chiers. 48
PRTS ? PARTITIONNEZ !
Lequel choisir ?
Actuellement, et pour faire simple, la plupart des ordinateurs sous Windows utilisent le NTFS et sous Linux, la plupart utilisent l'ext3. Nous allons choisir l'ext4, plus rcent et plus performant. Je peux vous proposer ceci pour vos partitions : Linux : ext4 ; Windows : NTFS (a ne bouge pas) ; Documents : ext4. Le but est que la partition Documents puisse tre lue et crite depuis Windows et Linux, an que vous puissiez accder vos documents, que vous soyez sous Windows ou Linux. L'ext4, comme vous le savez, fonctionne parfaitement sous Linux. Cependant, Windows ne le reconnat pas. . . moins d'installer un programme qui lui permettra de l'utiliser. Je peux vous recommander FS Driver, qui rend utilisables l'ext2, l'ext3 et l'ext4 sous Windows. Tlcharger FS Driver Code web : 696565
Prts ? Partitionnez !
Revenons l'installation d'Ubuntu, et plus prcisment l'tape 4, celle du partitionnement. La fentre de la gure 4.11 vous propose plusieurs options dans le cas o Windows est dj install. Installer les deux cte cte : Ubuntu va se faire automatiquement de la place sur votre disque dur et crer les partitions pour vous. C'est la solution la plus simple que vous devriez choisir si vous ne voulez pas entrer dans les dtails. En revanche, vous n'aurez pas de partition spciale pour les documents dans ce mode-ci. En bas de la fentre, vous pouvez dplacer le curseur pour dcider de l'espace que vous attribuez Windows et Ubuntu. Tout eacer et utiliser le disque entier : tout le disque sera format, partition Windows comprise. Ne faites cela que si vous voulez supprimer Windows ! Ubuntu sera install sur l'ensemble du disque dur. Dnir les partitions manuellement (avanc) : choisissez cette option si vous voulez crer vous-mmes les partitions. C'est plus complexe mais cela vous donnera plus de choix. En rsum : si vous voulez aller vite et faire simple, choisissez l'option Installer les deux cte cte . Sinon, choisissez le mode manuel : nous allons dcouvrir ci-dessous comment celui-ci fonctionne. 49
CHAPITRE 4.
50
PRTS ? PARTITIONNEZ !
Le partitionnement manuel
Je vais supposer que vous procdez un partitionnement manuel, et donc vous montrer pas pas comment a fonctionne avec l'outil de partitionnement prsent dans le gestionnaire d'installation d'Ubuntu. Mais avant cela, il faut que je vous fasse dcouvrir comment sont nommes les partitions du disque !
CHAPITRE 4.
52
PRTS ? PARTITIONNEZ !
Il se peut que vous ayez plus de partitions que moi. Par exemple, il est frquent de voir certains PC achets dans le commerce quips d'une toute petite partition restore , capable de restaurer certains logiciels de votre ordinateur en cas de formatage. Si vous en avez une, n'y touchez pas. Votre PC est peut-tre tatou . Pour plus d'informations, lisez la documentation Ubuntu ce sujet. Documentation tatouage Code web : 866792 Si cela vous semble trop compliqu, vous pouvez toujours opter pour une installation simple depuis Windows qui ne pose pas ce genre de problme de partitionnement. Nous avons dcrit cette procdure d'installation simplie au dbut du chapitre prcdent.
tape 1 : rduire la taille de la partition Windows
La premire tape consiste limiter l'espace ddi Windows pour faire de la place pour Ubuntu. Slectionnez la partition Windows en cliquant dessus (/dev/sda1 de type NTFS dans mon cas), puis cliquez sur le bouton Modier . Dans la fentre qui s'ouvre, vous pourrez modier la taille de la partition en entrant une nouvelle taille, plus petite, dans le premier champ, puis en cliquant sur Valider (gure 4.13).
Veillez laisser tout de mme assez de place Windows, sinon vous ne pourrez plus faire grand-chose dessus 3 .
3. Impossible d'installer un nouveau jeu s'il n'y a plus de place sur la partition, par exemple.
53
CHAPITRE 4.
C'est ce moment-l que la dfragmentation se rvle utile. Comme toutes les donnes ont t groupes au mme endroit, a vite que certains chiers gars soient accidentellement supprims. Ce serait un tantinet ballot, avouez. Vous devriez alors avoir de l'espace libre, comme sur la gure 4.14.
PRTS ? PARTITIONNEZ !
CHAPITRE 4.
Choisissez la taille que vous voulez pour cette partition, mais veillez laisser peu prs 1 Go (environ 1 000 Mo) de libre sur votre disque pour que l'on puisse crer une dernire partition aprs. Choisissez l encore le systme de chiers ext4. Pour le point de montage, choisissez /home (c'est le dossier Mes documents quivalent de Linux).
La n de l'installation
Il nous reste encore quelques petites tapes et nous aurons termin. 56
LA FIN DE L'INSTALLATION
57
CHAPITRE 4.
LA FIN DE L'INSTALLATION
59
CHAPITRE 4.
Installation !
Ouf ! C'est ni ! Une fentre rsume tous les choix que vous avez faits. C'est celle de la gure 4.21.
Il est conseill de brancher son ordinateur Internet avant l'installation : ainsi, Ubuntu mettra automatiquement jour tous les programmes. Si possible, connectez-vous via un cble (RJ45) et non en Wi-Fi : il y a plus de chances que a fonctionne du premier coup. Si vous ne pouvez pas vous connecter, ce n'est pas bien grave, vous pourrez toujours faire les mises jour ultrieurement.
Quelques chiers copis et quelques congurations automatiques plus tard, on vous proposera de redmarrer pour naliser l'installation de Linux. C'est bon, bravo, Linux est install ! :-) 60
LA FIN DE L'INSTALLATION
GRUB au dmarrage
Lors de chaque dmarrage, si vous avez choisi d'installer Linux sur le mme disque dur que Windows, on vous demandera quel OS vous voulez charger (gure 4.22).
En rsum
Un disque dur peut tre virtuellement dcoup en plusieurs sections direntes : c'est le principe du partitionnement. 61
CHAPITRE 4.
Pour installer Linux, vous devez modier le partitionnement de votre disque. L'opration consiste rduire l'espace allou Windows pour faire de la place Linux. Les partitions Windows stockent les chiers selon un systme appel NTFS, tandis que les partitions sous Linux utilisent plus souvent les systmes ext3 et ext4. On cre une partition spciale appele swap d'environ 1 Go, qui sert d'extension la mmoire vive lorsque celle-ci est pleine. Aprs l'installation, un outil appel GRUB vous demandera chaque dmarrage quel systme d'exploitation vous souhaitez lancer.
62
Chapitre
5
Dicult :
ous y voil enn ! Aprs avoir dcouvert ce qu'est Linux et appris comment l'installer, vous devriez prsent avoir cet OS oprationnel sur votre ordinateur. Parfait. Vous l'avez install, et maintenant ? On n'installe pas Linux juste pour la beaut du geste et pour dire a y est, je suis sous Linux ! . Si vous ne savez pas vous en servir, Linux risque davantage de faire oce de dcoration qu'autre chose sur votre ordinateur. Toute la suite de ce cours sera donc ddie la dcouverte et l'tude approfondie de Linux. Vous n'imaginez pas encore toutes les choses que vous allez apprendre. ;-) Nous allons commencer en douceur par la dcouverte de Gnome. C'est l'un des gestionnaires de bureau de Linux les plus utiliss, et c'est notamment celui que l'on trouve par dfaut dans Ubuntu. Simple, clair et facile prendre en main, il conviendra la plupart des nouveaux utilisateurs de Linux. Ce chapitre vous propose une petite visite guide de l'environnement Gnome.
63
CHAPITRE 5.
Mais pourquoi faut-il s'authentier chaque fois que l'on dmarre Linux ? Si je suis seul, ce n'est pas la peine de mettre un mot de passe. . .
Il est vrai que sous Windows on n'a pas trop l'habitude de s'authentier, surtout sur son ordinateur domestique. . . quoique les habitudes sont en train de changer de ce ct-l. Sous Linux, la conception est totalement dirente. C'est un OS qui se veut vraiment multiutilisateur, c'est--dire que plusieurs personnes peuvent utiliser le mme ordinateur de faon simultane (en le contrlant distance par l'internet par exemple). Il y a une vraie politique de scurit et c'est pour cela que mme pour l'ordinateur de la maison chacun doit avoir son login et son mot de passe. Cela permet notamment de savoir qui appartient tel ou tel chier. 64
Les options
Quelques options vous sont proposes au bas de la fentre de login. Vous pouvez notamment y choisir votre gestionnaire de bureau (gure 5.2).
CHAPITRE 5.
votre Gnome ! Amusez-vous bien. :-) droite de ces menus, une barre de raccourcis vous permet de lancer plus rapidement les programmes que vous utilisez souvent. Pour en ajouter un, faites un clic droit sur une zone vide du tableau de bord et cliquez sur Ajouter au tableau de bord . Sur le ct droit de ce dernier vous retrouvez quelques icnes de notication ainsi que la date. Enn, un bouton en haut droite vous propose d'arrter votre ordinateur ou bien de le redmarrer, de changer d'utilisateur, etc.
CHAPITRE 5.
les dossiers et chiers de votre disque dur et de les ouvrir. C'est donc un programme que vous risquez de lancer souvent. Pour ouvrir Nautilus, le plus simple est de se rendre dans le menu Raccourcis et d'ouvrir Poste de travail, comme l'indique la gure 5.6.
69
CHAPITRE 5.
devrait vous tre familire tant il ressemble l'outil de Windows. Vous mettrez un peu de temps vous faire l'organisation des dossiers qui est un peu particulire sous Linux, mais vous nirez par prendre vos repres. Pour le moment, je vous conseille d'utiliser votre rpertoire personnel (ici le mien s'appelle mateo21) ; vous pouvez y stocker tous vos documents, vos vidos, votre musique, etc.
70
CHAPITRE 5.
Et les mises jour ne peuvent pas se faire automatiquement, sans que j'aie besoin chaque fois de cliquer sur Installer les mises jour ?
Si vous ne voulez pas vous prendre la tte et tre srs d'avoir un systme toujours 72
73
CHAPITRE 5.
jour, le mieux est de congurer le gestionnaire de mises jour pour qu'il installe les nouveauts sans demander votre autorisation. Retournez dans le menu Applications Ajouter & Enlever. Dans le bas de la fentre qui s'ouvre, cliquez sur Prfrences. Cliquez ensuite sur l'onglet Mises jour puis slectionnez Installer les mises jour de scurit sans conrmation (gure 5.16).
En rsum
Gnome est un des plus clbres gestionnaires de bureau. Il est install par dfaut avec Ubuntu. Vous devez vous connecter au dmarrage de la machine, en indiquant votre nom d'utilisateur et votre mot de passe. Les menus en haut de l'cran sous Gnome donnent accs vos programmes et chiers. La logithque Ubuntu est un outil simple d'emploi qui vous permet d'installer de nouveaux programmes. Les mises jour de tous les programmes sont centralises et peuvent s'eectuer automatiquement.
74
Chapitre
6
Dicult :
prs avoir dcouvert Gnome, l'environnement de bureau par dfaut d'Ubuntu, nous allons ici nous pencher sur KDE. Celui-ci est utilis par dfaut si vous installez Kubuntu (une variante d'Ubuntu) mais peut tout aussi bien tre install sous Ubuntu, comme nous allons le voir. L'objectif est avant tout de vous montrer la diversit qui rgne dans le monde de Linux : celui-ci peut prendre plusieurs formes selon le gestionnaire de bureau que l'on utilise. KDE est assez dirent de Gnome, vous allez vite vous en rendre compte, mais il est trs plaisant utiliser. Ce chapitre sera l'occasion de vous faire une premire ide de KDE qui est, avec Gnome, un des gestionnaires de bureau les plus utiliss et les plus clbres.
75
CHAPITRE 6.
CHAPITRE 6.
Le bureau et le menu K
Aprs un petit instant de chargement, vous vous retrouvez sur le bureau de KDE, prsent sur la gure 6.5. Le bureau est assez riche au premier abord. En fait, il est compltement personnalisable : on peut y ajouter toute une varit de widgets, appels Plasmodes . Vous pouvez les congurer en cliquant sur l'icne situe tout en haut droite de l'cran. En bas de l'cran, on retrouve une barre des tches qui rappelle en plusieurs points celle de Windows ; vous ne devriez pas tre trop dpayss. Sous KDE, on l'appelle le tableau de bord. 78
LE TABLEAU DE BORD
Le tableau de bord
Le tableau de bord, normalement prsent en bas de l'cran, est un outil complet qui vous permet de lancer vos applications, d'accder vos chiers ou encore de visualiser l'tat du systme. Intressons-nous dans un premier temps la partie gauche de ce tableau de bord.
Le menu K
C'est le menu principal, le plus important de KDE (gure 6.7). 79
CHAPITRE 6.
80
LE TABLEAU DE BORD
Il permet de lancer des applications, de congurer le systme et d'arrter l'ordinateur. Il ressemble d'ailleurs au menu Dmarrer de Windows 7. Le menu K s'ouvre sur vos applications favorites. Un clic droit sur l'une d'elles permet de l'ajouter ou de la retirer de vos favoris pour un accs plus rapide. Si KDE est en anglais, recherchez le programme Country & Region Language . Vous pouvez tout simplement taper lang tandis que le menu K est ouvert (gure 6.8).
CHAPITRE 6.
L'explorateur QuickAccess
Cette seconde icne du tableau de bord ouvre directement votre rpertoire personnel ( home ). Vous pouvez l'utiliser pour accder rapidement vos chiers (gure 6.10) sans passer par le programme Dolphin.
Ensuite, une srie d'icnes sont prsentes dans ce que l'on appelle la zone de notication. Le principe est exactement le mme que sous Windows : certains programmes qui tournent apparaissent ici et vous informent des vnements en cours, du volume audio, de l'tat de la batterie, etc. Enn, vous avez la date et, tout droite, une petite icne qui vous permet de personnaliser compltement le tableau de bord. Voil pour ce rapide tour d'horizon du tableau de bord. Bien sr, ces icnes peuvent changer d'une version l'autre d'Ubuntu et vous pouvez recongurer le tableau de bord comme bon vous semble. N'hsitez pas le personnaliser jusqu' ce que vous vous sentiez un peu plus chez vous . :-)
Notez que le navigateur web de KDE, Konqueror, peut aussi jouer le rle d'explorateur de chiers.
Dans un cas comme dans l'autre, la fentre de l'explorateur Dolphin s'ouvre (gure 6.13). Son fonctionnement n'est, l encore, pas trs dirent de l'explorateur Windows. Aprs quelques minutes de dcouverte, vous vous serez vite adapts ! La principale particularit de Dolphin (et de KDE en gnral) est qu'il faut cliquer une seule fois pour ouvrir un chier ou un dossier. Inutile donc de double-cliquer tout va ! Vous pouvez ouvrir plusieurs onglets (comme dans un navigateur web) en eectuant la combinaison de touches Ctrl + T. Mieux encore, vous pouvez scinder la fentre en deux (gure 6.14) pour voir simultanment deux dossiers dirents ! Pour cela, vous pouvez appuyer sur la touche F3 ou cliquer sur le bouton Scinder en haut dans la barre d'outils. Ainsi, vous pouvez facilement dplacer ou copier des chiers d'un dossier l'autre ! Ces particularits mises part, n'ayez crainte, vous trouverez vite vos marques sous KDE.
Je vous invite maintenant ouvrir la Conguration du systme (quivalent du Panneau de conguration de Windows) qui vous permettra de personnaliser au mieux votre KDE. Pour l'ouvrir, vous savez ce qu'il vous reste faire : utiliser le menu K !
83
CHAPITRE 6.
Si vous souhaitez installer des programmes sous KDE, lancez le programme Ubuntu Software Center ; il s'agit de la logithque Ubuntu que nous avons dcouverte sous Gnome.
En rsum
KDE est un autre gestionnaire de bureau trs clbre, install par dfaut si vous avez tlcharg Kubuntu. Si vous avez choisi Ubuntu et que vous utilisez donc Gnome, vous pouvez installer KDE en passant par la logithque. Il sut d'installer kubuntu-desktop (version complte avec de nouveaux programmes) ou kde-minimal (version allge). Vous pouvez slectionner votre gestionnaire de bureau au dmarrage, sur l'cran de connexion. Le tableau de bord de KDE est entirement personnalisable. Vous pouvez lancer vos programmes depuis le menu K, similaire au menu Dmarrer de Windows.
85
CHAPITRE 6.
86
Chapitre
7
Dicult :
a virtualisation est une technique de plus en plus rpandue en informatique : cela consiste faire tourner un ordinateur virtuel dans votre ordinateur. Imaginez : cela vous permet de lancer Linux l'intrieur d'une fentre Windows ou Windows l'intrieur d'une fentre Linux, voire pourquoi pas Linux dans une fentre Linux ! La virtualisation peut sembler assez impressionnante et complexe, mais elle est devenue accessible au grand public ces dernires annes. Dans ce chapitre, nous allons apprendre utiliser le logiciel libre Virtual Box pour installer Linux l'intrieur de Windows. Le gros avantage de cette technique est que Linux sera isol dans la machine virtuelle : il ne risque absolument pas d'altrer le bon fonctionnement de Windows. Une technique rserver ceux qui souhaitent tester Linux sans aucun risque !
87
CHAPITRE 7.
Dans ce chapitre, nous allons dcouvrir comment lancer Linux l'intrieur d'une fentre Windows (gure 7.1). C'est le principe de la virtualisation !
Installer VirtualBox
Pour commencer, nous devons tlcharger et installer un logiciel de virtualisation. Celui que je vous recommande s'appelle VirtualBox. Il a l'avantage d'tre libre et gratuit, et il existe en version Windows, Linux et Mac OS X. Rendez-vous sur le site de VirtualBox pour tlcharger la dernire version correspondant votre systme d'exploitation :
Si votre ordinateur est quip de Windows, tlchargez VirtualBox pour Windows mme si vous comptez l'utiliser pour installer Linux. Je reconnais que cette histoire d'ordinateur dans l'ordinateur peut prter confusion, donc imaginez tout simplement que vous allez installer un nouveau programme pour Windows. Si vous avez Mac OS X, tlchargez la version Mac OS X.
88
INSTALLER VIRTUALBOX
CHAPITRE 7.
couper votre accs Internet (gure 7.4). En eet, VirtualBox doit tablir un pont de connexion entre votre ordinateur et la machine virtuelle pour que celle-ci puisse accder Internet. Cela provoque une rupture temporaire de l'accs Internet de l'ordre de quelques secondes 1 .
90
CHAPITRE 7.
On vous demande dans un premier temps de lui donner un nom. Vous pouvez tout simplement l'appeler Ubuntu . Vous remarquerez que les champs en dessous se remplissent automatiquement pour indiquer le type de systme d'exploitation qui sera install dans la machine virtuelle (gure 7.7).
VirtualBox est capable de faire tourner tous ces systmes d'exploitation, mais il vous faut le CD d'installation ou l'image disque de ces OS pour les lancer. VirtualBox n'est pas un outil magique : sans le CD d'installation, il ne saura pas quoi faire.
Vous devez ensuite indiquer quelle quantit de mmoire vive (RAM) vous souhaitez rserver la machine virtuelle (gure 7.8). En eet, pour que celle-ci fonctionne correctement, il va lui falloir de la mmoire. . . comme pour tout ordinateur normal ! Il va donc falloir donner un peu de mmoire la machine : je vous recommande au moins 512 Mo, voire 1 Go si possible 3 . Il nous reste maintenant crer le disque dur de la machine virtuelle. VirtualBox va crer une sorte de gros chier sur votre disque qui reprsentera le disque dur de la machine. Laissez l'option Crer un nouveau disque dur slectionne (gure 7.9). Une nouvelle fentre s'ouvre alors : l'assistant de cration de disque dur virtuel (gure 7.10).
3. VirtualBox peut occuper jusqu' 50% de votre mmoire vive. Je dispose de 3 Go, la quantit maximale que l'on me propose est donc 1,5 Go.
92
93
CHAPITRE 7.
N'oubliez pas que la taille de l'image disque correspond la taille maximale qui pourra tre utilise par la machine virtuelle. Si vous avez l'intention d'installer de gros programmes, prvoyez un peu plus de place. Pour une installation classique et basique d'Ubuntu, 8 Go devraient cependant sure.
Les assistants de cration sont enn termins, ouf ! :-) Ils ne sont pas si complexes en ralit ; il y a quelques annes, la cration de machine virtuelle tait plutt rserve aux experts. En quelques clics, nous avons congur la machine, qui est maintenant prte tre lance ! 94
95
CHAPITRE 7.
Congurer le lecteur CD
Avant de lancer la machine virtuelle, vous avez besoin du CD d'installation d'Ubuntu, exactement comme si vous dmarriez votre ordinateur pour y installer Linux. Deux choix s'orent vous. Vous avez dj grav Ubuntu sur CD : il sut d'insrer le CD dans le lecteur avant de lancer la machine virtuelle. Il s'agit du cas le plus simple. Vous avez tlcharg l'image (.iso) mais ne l'avez pas grave sur CD : inutile d'utiliser un CD pour cela, VirtualBox est capable de lire directement l'image ISO. Dans le cas o vous avez l'image ISO sur votre disque dur et o vous ne souhaitez pas graver de CD, vous devez congurer la machine virtuelle pour qu'elle utilise le chier .iso comme CD. Sur l'cran d'accueil d'Ubuntu, cliquez tout d'abord sur le nom de la machine virtuelle disponible dans la liste puis cliquez sur le bouton Conguration . 96
Dans la fentre qui s'ouvre, slectionnez Stockage dans la liste de gauche puis slectionnez la ligne Vide sous Contrleur IDE (gure 7.14).
97
CHAPITRE 7.
Un des gros avantages de la machine virtuelle est qu'il est possible d'enregistrer son tat n'importe quel moment. C'est une sorte de sauvegarde instantane. Pour y accder, allez dans le menu Machine Prendre un instantan. Vous pourrez par la suite revenir au moment exact de la sauvegarde.
Vous pouvez, si vous le dsirez, acher Ubuntu en plein cran. Il sut d'eectuer la combinaison de touches Ctrl Droite + F (vous pouvez aussi aller dans le menu Machine Passer en plein cran). Malheureusement, comme vous allez le constater, Ubuntu n'occupe pas tout votre cran. Pour y remdier, il va falloir installer les 99
CHAPITRE 7.
additions invit. . .
101
CHAPITRE 7.
Vous devrez nouveau indiquer votre mot de passe par mesure de scurit. Une console s'ouvre et les additions s'installent dans Ubuntu. Patientez jusqu' ce que l'on vous demande d'appuyer sur Entre ( Return en anglais) pour fermer la fentre (gure 7.23).
Figure 7.23 Les additions sont installes ! Il faut alors appuyer sur Entre et redmarrer. Les additions sont installes ! Pour qu'elles soient prises en compte, vous devrez ensuite redmarrer Ubuntu.
Vous pouvez maintenant partager un dossier entre Windows et Ubuntu : rendez-vous dans le menu Priphriques Dossiers partags. Vous pourrez y indiquer un dossier existant de Windows et le nom du dossier quivalent dans Ubuntu.
En rsum
VirtualBox est un outil qui permet de faire tourner un ordinateur virtuel au sein d'un systme d'exploitation. Nous utilisons ici VirtualBox pour installer Linux l'intrieur de Windows. Il n'y a aucun risque de conit entre les deux car la machine virtuelle est cloisonne. Vous pouvez utiliser la machine virtuelle comme un vritable ordinateur mais vous perdez lgrement en performances. Cette technique est rserver ceux qui souhaitent ne prendre aucun risque lors de l'installation d'Ubuntu ou qui dsirent simplement essayer la distribution. Une fois Ubuntu install dans la machine virtuelle, il est conseill d'installer les additions invit. Cela amliorera les performances et vous permettra notamment d'utiliser Ubuntu en plein cran, de partager des dossiers et le presse-papier, etc.
103
CHAPITRE 7.
104
Deuxime partie
Manipuler la console et les chiers
105
Chapitre
8
Dicult :
La console, a se mange ?
out au long de la premire partie du livre, nous avons pass notre temps dcouvrir en douceur Linux, son bureau et son interface graphique. Par rapport d'autres systmes d'exploitation comme Windows, c'est un peu dpaysant au dbut, mais mine de rien, on retrouve beaucoup de concepts similaires. Je pense donc que vous n'aurez plus besoin de moi pour tre capables de manipuler correctement l'interface graphique. Les choses intressantes commencent maintenant. C'est partir d'ici qu'un utilisateur classique de Windows met les pieds dans un environnement totalement nouveau. Vous ne pouvez pas avoir d'a priori, et il y a de fortes chances que ce soit un domaine de l'informatique que vous n'ayez jamais approch (non, non, DOS ne compte pas). Vous n'avez pas ide de la richesse quasi-innie oerte par la console. Personne ne peut d'ailleurs prtendre la matriser entirement, c'est vous dire ! Vous aurez donc toujours quelque chose dcouvrir. :-)
107
CHAPITRE 8.
LA CONSOLE, A SE MANGE ?
Mais pourquoi ont-ils invent la console au lieu de l'interface graphique, d'abord ? C'est quand mme plus pratique une interface graphique avec une souris ; c'est plus intuitif ! C'est juste pour faire pro, faire compliqu pour faire compliqu et s'assurer que l'informatique reste seulement la porte de quelques initis ? Pourquoi ne pas avoir supprim la console ? C'est archaque 1 !
Que nenni ! Il y a une explication tout ; voici une rponse point par point.
108
109
CHAPITRE 8.
LA CONSOLE, A SE MANGE ?
La premire ligne est la commande que j'ai tape, la seconde le rsultat. Il y avait donc 510 images JPEG dans le dossier, et on a obtenu le rsultat en moins d'une seconde ! On peut mme faire encore plus fort et enregistrer directement ce nombre dans un chier texte :
ls El | grep jpg | w El b njpgFtxt
. . . et on peut aussi envoyer le chier nb_jpg.txt sur Internet par FTP ou un ami par e-mail, le tout en une ligne ! La console n'est donc pas morte et n'a pas du tout prvu de l'tre ! La plupart des commandes de la console de Linux sont des copies d'Unix, ce vieil OS dont je vous ai parl au tout dbut, anctre parmi les anctres. N'allez pas croire que les programmes d'Unix ont t copis ou pirats par Linux ; c'est juste que leur mode d'emploi est le mme. Les programmes ont t rcrits par un groupement de programmeurs issus de ce qu'on appelle le projet GNU. Ce projet a fusionn au bout de quelque temps avec le cur du systme d'exploitation Linux pour donner au nal GNU/Linux, qu'on crit en pratique juste Linux car c'est plus court. Mais tout a, je vous l'ai dj dit dans le premier chapitre. L'avantage ? Les commandes n'ont pas boug et ne bougent pas depuis l'poque d'Unix (soit depuis les annes 60). Ce sont les mmes. Quelqu'un qui utilisait Unix dans les annes 60 est capable de se dbrouiller avec un Linux d'aujourd'hui. Et il y a fort parier que ce sera pareil pour les nombreuses annes venir. Vous avez donc juste apprendre vous en servir une fois. O.K., il y aura du boulot, mais aprs ce sera quelque chose qui pourra vous servir toute votre vie !
Ce que vous apprendrez dans les chapitres suivants sera l'utilisation de commandes de type Unix. L'avantage, c'est que a ne marchera pas seulement sous Linux mais aussi sous tous les OS galement bass sur Unix ! En eet, quelques exceptions prs, tout ce que vous verrez pourra donc tre fait sous les OS bass sur Unix, en particulier Mac OS X. Si vous avez Mac OS X et que vous souhaitez ouvrir une console, faites Pomme + Shift + U pour ouvrir les Utilitaires, et slectionnez Terminal comme le montre la capture d'cran de la gure 8.2.
Lisez bien tous les paragraphes qui suivent avant d'excuter les commandes que je vais vous donner. Ce n'est pas dangereux rassurez-vous, mais c'est juste que si vous vous retrouvez en console avant d'avoir lu comment en sortir, vous aurez l'air bien embts. ;-)
Je vais supposer que vous vous tes connects, c'est--dire que vous avez entr votre login et votre mot de passe. Vous tes donc sur votre gestionnaire de bureau, ici Gnome (gure 8.3). Vous trouvez qu'il y a trop de couleurs ? Que a manque de mots compliqus ? Pas de problme ! Voici les raccourcis connatre pour accder la console : Ctrl + Alt + F1 : terminal 1 (tty1) ; Ctrl + Alt + F2 : terminal 2 (tty2) ; Ctrl + Alt + F3 : terminal 3 (tty3) ; Ctrl + Alt + F4 : terminal 4 (tty4) ; Ctrl + Alt + F5 : terminal 5 (tty5) ; Ctrl + Alt + F6 : terminal 6 (tty6) ; Ctrl + Alt + F7 : retour au mode graphique (ouf !). 111
CHAPITRE 8.
LA CONSOLE, A SE MANGE ?
Le login
Vous ne pouvez pas utiliser tout de suite la console : il faut d'abord vous logger. C'est ce que vous demande la dernire ligne :
mteoPIEdesktop loginX
mateo21-desktop : c'est le nom que vous avez donn votre ordinateur lors de l'instal-
lation. Votre ordinateur se prsente et vous rappelle o vous tes, en quelque sorte. a a l'air inutile comme a, mais avec Linux on peut se connecter un autre PC facilement en console (on en parlera plus loin), et parfois on ne sait plus si on est dans la console de son PC ou dans celle d'un autre. Bon, entrez votre login ; dans mon cas c'est mateo21. On vous demande ensuite votre mot de passe :
sswordX
L, vous rentrez votre mot de passe. Dans mon cas c'est ooops euh. . . j'ai rien dit. Ne soyez pas tonns si les lettres que vous tapez n'apparaissent pas. En fait, il n'y a mme pas d'toiles qui s'achent l'cran. Cela permet d'viter qu'une personne derrire vous compte le nombre de caractres de votre mot de passe 3 . Si tout va bien, vous devriez voir l'cran de la gure 8.5.
113
CHAPITRE 8.
LA CONSOLE, A SE MANGE ?
mteoPIdmteoPIEdesktopX~6
noter qu'une combinaison similaire permet de redmarrer le serveur X, c'est--dire l'interface graphique. Contrairement aux apparences, a ne redmarre pas l'ordinateur mais juste l'lment graphique. Les consoles continuent tourner derrire. Cette combinaison spciale, c'est Ctrl + Alt + Backspace (la touche Retour arrire ). Attention, c'est assez radical. Pensez donc enregistrer vos documents avant d'essayer. Vous ne devriez pas avoir le faire souvent, sauf si l'interface graphique est plante (rare) ou si on vous demande de le faire pour prendre en compte une nouvelle conguration de X. Je vous dirai a en temps voulu. Notez enn que sous les dernires versions d'Ubuntu, ce raccourci pourtant commun a t remplac par Alt + Impr.cran + K . La combinaison Ctrl + Alt + Backspace a t considre comme trop frquemment utilise de manire inapproprie par les dbutants habitus une combinaison similaire prsente sous Windows.
Sous KDE
Pour KDE, il faut se rendre dans le menu K / Systme / Konsole. La console de KDE est visible sur la gure 9.1. Vous pouvez vous amuser changer la couleur de fond ou insrer une image la 115
CHAPITRE 8.
LA CONSOLE, A SE MANGE ?
Sous Gnome
Si vous tes sous Gnome, rendez-vous dans Applications / Accessoires / Terminal. Voyez la console de Gnome sur la gure 8.8.
Vous noterez que les deux types de console permettent d'ouvrir plusieurs onglets. Pour celle de KDE, il y a une petite icne en bas gauche, et pour celle de Gnome il y a le menu Fichier / Ouvrir un onglet. Les onglets sont en gnral trs pratiques car ils permettent de multiplier les consoles et donc de faire plusieurs choses en mme temps.
Telnet et SSH
Pour communiquer entre votre ordinateur et le serveur, il faut un protocole. C'est un ensemble de rgles pour que deux ordinateurs puissent discuter entre eux. . . un peu comme si deux personnes devaient parler la mme langue pour avoir une conversation. 117
CHAPITRE 8.
LA CONSOLE, A SE MANGE ?
Il existe des tonnes et des tonnes de protocoles pour communiquer par Internet, mais pour ce qui est d'accder la ligne de commande distance, c'est--dire la console, il y en a deux principaux. Telnet : le protocole le plus basique, qui prsente le gros dfaut de ne pas crypter les donnes changes entre vous et le serveur. Si un pirate coute vos changes par un moyen ou un autre, il pourrait rcuprer des informations sensibles, en particulier votre mot de passe lorsque vous l'envoyez la connexion. Ce moyen de connexion reste utilis mais peu par rapport SSH. SSH : c'est de trs loin le protocole le plus utilis (et que l'on prfre) car il permet de crypter les donnes et de scuriser ainsi la connexion avec le serveur. Vous l'aurez compris, vous entendrez donc davantage parler de SSH que d'autre chose.
PuTTY
Pour accder distance un ordinateur sous Linux connect Internet, vous avez besoin d'un programme spcial capable de restituer la ligne de commande distance. Ce qui est bien, c'est que vous n'avez pas forcment besoin d'tre sous Linux pour vous connecter un autre ordinateur utilisant cet OS ; on peut trs bien le faire depuis Windows, et c'est d'ailleurs la procdure que je vais vous montrer ici. Il existe plusieurs programmes capables de se connecter en SSH un serveur Linux. Le plus clbre sous Windows est srement PuTTY : il est gratuit, lger et ne ncessite mme pas d'installation (juste un excutable lancer). Tlcharger PuTTY Code web : 396111 Pour le tlcharger, allez sur le site web du logiciel grce au code web ci-dessus. Rendezvous sur la page Download et cliquez sur putty.exe . Lorsque vous le lancez, la fentre de conguration s'ache (gure 8.9). Il y a beaucoup de pages d'options, comme le montre la section gauche de la fentre. Dans la majeure partie des cas, vous n'aurez pas besoin d'y aller, heureusement. Seule la premire page est en fait vraiment importante : vous devez indiquer en haut dans le champ Host Name le nom d'hte du serveur (dans mon cas bart.siteduzero.com) ou encore l'adresse IP de l'ordinateur, ce qui marche aussi bien (c'est juste plus dicile retenir). Vriez que le type de connexion slectionn en dessous est bien SSH, puis cliquez sur le bouton Open tout en bas.
Si vous avez l'habitude de vous connecter plusieurs serveurs dirents, sachez qu'il est possible de sauvegarder les IP et congurations pour se connecter chacun d'eux. Utilisez la section Saved sessions au centre pour enregistrer ou ouvrir des connexions pr-enregistres.
Aprs avoir cliqu sur Open, une fentre vous demandera lors de la premire connexion au serveur si vous voulez stocker l'empreinte de ce dernier. C'est une scurit pour vrier que le serveur n'a pas chang depuis la dernire connexion et donc pour viter 118
CHAPITRE 8.
LA CONSOLE, A SE MANGE ?
Voil, vous n'avez plus qu' vous connecter. Indiquez votre login (par exemple mateo21), puis tapez Entre. On vous demande ensuite votre mot de passe ; tapez-le puis faites Entre.
Encore une fois, il est normal de ne pas voir d'toiles lorsque vous tapez votre mot de passe. C'est une scurit supplmentaire pour viter que quelqu'un derrire vous ne compte le nombre de caractres. Soyez donc rassurs, le serveur reoit bien votre mot de passe. Tapez-le comme si de rien n'tait.
Si le login et le mot de passe sont bons, vous avez accs la console du serveur sous Linux comme si vous tiez devant (gure 8.11) !
En rsum
Bien que rebutante au premier abord, la console nous ore une puissance importante. Elle nous permet d'excuter des actions simples comme complexes, qui sont parfois impossibles raliser avec une interface graphique. On peut lancer une console en plein cran avec les touches Ctrl + Alt + F1 F6, mais il est plus simple aujourd'hui d'ouvrir une console via une interface graphique l'aide du programme Terminal (sous Gnome) ou Konsole (sous KDE). On peut se connecter en console distance son ordinateur sous Linux grce au protocole SSH. Cette technique est trs frquemment utilise pour administrer des serveurs sur Internet quips de Linux.
121
CHAPITRE 8.
LA CONSOLE, A SE MANGE ?
122
Chapitre
9
Dicult :
hers amis, le grand jour est enn arriv ! Vous allez rentrer votre premire commande en console ! a va, pas trop stresss ? Je vous rassure, nous allons commencer par des choses trs simples pour nous familiariser avec la console. Nous allons vraiment voir le B.A.-BA, le guide de survie lmentaire en quelque sorte.
123
CHAPITRE 9.
L'invite de commandes
Je suppose partir de maintenant que vous avez ouvert une console. Si vous ne savez pas faire, c'est que vous n'avez pas lu le chapitre prcdent. Le mieux, comme je vous l'ai dit, est d'ouvrir une console dans le mode graphique. Le programme Konsole sous KDE ou Terminal sous Gnome fera donc trs bien l'aaire (gure 9.1).
a, c'est ce que vous voyez l'cran. Vous n'avez encore rien crit, mais l'ordinateur vous dit bonjour sa manire 1 . Ce que vous voyez l est ce qu'on appelle l'invite de commandes. C'est un message qui vous invite rentrer une commande en vous donnant par la mme occasion une foule d'informations. Cette invite s'ache avant chaque commande que vous tapez. Bien : dcortiquons cette invite de commandes parce qu'elle est trs intressante. mateo21 : le premier lment est votre pseudonyme. C'est le pseudo sous lequel vous vous tes loggs. En eet, rappelez-vous : on peut crer plusieurs comptes utilisateurs sous Linux. Il est en gnral conseill d'en gnrer un par personne susceptible d'utiliser l'ordinateur (un pour chaque membre de la famille, par exemple). Nous verrons plus tard comment rajouter des comptes utilisateurs.
1. Bon, O.K., j'avoue que c'est une faon trs spciale de dire bonjour.
124
L'INVITE DE COMMANDES
@ : ce symbole n'indique rien de particulier. C'est le symbole at qui signie chez . Si on lit l'invite de gauche droite, on doit donc comprendre mateo21 chez . mateo21-desktop : a, c'est le nom de l'ordinateur sur lequel vous tes en train de travailler. Dans mon cas il s'appelle mateo21-desktop, mais j'aurais pu lui attribuer n'importe quel nom lors de l'installation. Par exemple, on a l'habitude de donner le nom d'un membre des Simpson chacun des serveurs du Site du Zro : Lisa, Bart, Itchy, Scratchy. . . Cela permet de savoir de quelle machine on parle quand on dit Ouh l, Bart est surcharg, il faudrait voir quel est le programme qui ralentit tout . Si vous suivez toujours, la ligne d'invite de commandes se lit donc mateo21 chez mateo21-desktop . En d'autres termes, je suis identi en tant que mateo21 sur la machine mateo21-desktop. : : nouveau, ce symbole ne veut rien dire de spcial, c'est un sparateur. ~ : a, c'est le dossier dans lequel vous vous trouvez actuellement. Vous pouvez naviguer de dossier en dossier dans la console et il est trs utile qu'on vous rappelle systmatiquement o vous vous trouvez avant chaque commande. Pour information, le symbole ~ signie que vous tes dans votre dossier personnel, ce qu'on appelle le home sous Linux ; c'est l'quivalent du dossier Mes documents de Windows. Nous tudierons plus en dtail le fonctionnement des dossiers sous Linux dans le prochain chapitre. $ : ce dernier symbole est trs important ; il indique votre niveau d'autorisation sur la machine. Il peut prendre deux formes direntes : $ : signie que vous tes en train d'utiliser un compte utilisateur normal , avec des droits limits (il ne peut pas modier les chiers systme les plus importants). Mon compte mateo21 est donc un compte normal avec des droits limits ; # : signie que vous tes en mode superutilisateur, c'est--dire que vous tes connects sous le pseudonyme root . Le root est l'utilisateur matre qui a le droit de tout faire sur sa machine (mme de la dtruire !). Nous verrons le mode root plus en dtail plus tard ; pour l'instant nous restons dans un compte utilisateur limit, ainsi nous ne risquons pas de faire de btise. Comme vous le voyez, une fois qu'on parle la mme langue que l'invite de commandes, on comprend ce qu'elle veut dire ! Bonjour et bienvenue, vous tes mateo21 sur la machine mateo21-desktop. Vous vous trouvez actuellement dans votre dossier home et possdez des droits utilisateur limits. La temprature extrieure est de.
Comme un peu tout sous Linux, l'invite de commandes est totalement paramtrable. Vous pouvez la raccourcir si vous trouvez qu'elle est trop longue, ou la rallonger si vous trouvez qu'elle ne donne pas assez d'informations. Vous pouvez en thorie mettre vraiment tout ce que vous voulez dans l'invite, comme par exemple l'heure actuelle (par contre, pour la temprature extrieure il faudra repasser). Nous verrons comment changer cela lorsque vous aurez appris vous servir d'un diteur de texte !
125
CHAPITRE 9.
Commandes et paramtres
On travaille dans la console en tapant ce qu'on appelle des commandes. Ces dernires tant nombreuses, vous ne pourrez jamais toutes les connatre. . . et ce n'est pas le but : le but, c'est que vous sachiez vous servir par cur de la plupart des commandes courantes et, pour les moins courantes, que vous soyez capables d'apprendre vous en servir en lisant leur manuel d'utilisation. Le manuel d'utilisation est la vritable bible de tous les linuxiens. Vous verrez rapidement qu'ils ne jurent que par a. Pourquoi ? Parce que c'est tout simplement un outil de rfrence, l o l'on peut trouver la rponse TOUTES ses questions pour peu qu'on sache lire le manuel et qu'on prenne la peine de le faire. Un chapitre entier du livre vous apprendra lire le manuel : c'est vraiment trs important.
Pour information, il est courant de voir un linuxien dire RTFM aux dbutants qui posent des questions qu'il estime simples . RTFM est l'abrviation de Read the fucking manual ! , ce qui veut dire grosso modo Lis le p*** de manuel ! . Ce n'est pas vraiment une insulte en fait, mais plutt une sorte de. . . soupir d'exaspration. Pour viter qu'on vous dise a un jour, je vous conseille donc de bien ouvrir vos oreilles quand je vous expliquerai comment utiliser le manuel. ;-)
La premire ligne contient l'invite de commandes suivie de la commande que j'ai tape. La seconde ligne est la rponse de l'ordinateur cette commande. Je suppose que vous avez devin comme des grands ce que l'on vient de faire : on a demand quelles taient la date et l'heure ! Vous en voulez encore ? O.K., alors essayons une toute autre commande : tapez ls. C'est l'abrviation de list , qui signie lister les chiers et dossiers du rpertoire actuel .
mteoPIdmteoPIEdesktopX~6 ls hesktop ixmples smges
Cela signie que le rpertoire actuel est constitu de trois dossiers : Desktop, Examples et Images. En gnral, le systme colore les lments pour que l'on puisse distinguer 126
COMMANDES ET PARAMTRES
facilement les dossiers des chiers. Si vous n'avez aucune rponse, c'est que vous tes dans un dossier qui ne contient ni chier ni dossier. Voil, c'est aussi simple que cela. Une commande est constitue d'un mot et ne contient aucun espace. Dans des cas trs simples comme ceux que l'on vient de voir, il sut juste de taper la commande pour avoir une rponse ; mais dans la quasi-totalit des cas on peut (et parfois on DOIT) rentrer des options, qu'on appelle paramtres.
Les paramtres
Les paramtres sont des options que l'on crit la suite de la commande. La commande et les paramtres sont spars par un espace, comme ceci :
mteoPIdmteoPIEdesktopX~6 ommnde prmetres
Les paramtres peuvent eux-mmes contenir des espaces, des lettres, des chires. . . un peu de tout, en fait. Il n'y a pas de rgle vritable sur la forme des paramtres, mais heureusement les programmeurs ont adopt une sorte de convention pour que l'on puisse reconnatre les dirents types de paramtres.
Attention la casse des paramtres (majuscules / minuscules) ! Si vous crivez -u, cela n'a en gnral pas du tout le mme sens que -U !
Faisons un essai avec la commande ls et rajoutons-lui le paramtre a (en minuscule) : 127
CHAPITRE 9.
mteoPIdmteoPIEdesktopX~6 ls E F Fgonfd FF FgimpEPFP Fshhistory FgksuFlok Fshlogout Fgnome Fshr FgnomeP Fonfig FgnomePprivte hesktop FgstremerEHFIH Fdmr FgtkrEIFPEgnomeP Fesduth Fsgiuthority Fevolution Fions ixmples Flesshst Ffe Flol Ffontonfig Fmromedi Fgim Fmetity Fgonf Fmozill
FmozillEthunderird Fnutilus Fprofile FreentlyEused FreentlyEusedFxel Fssh Fsudosdminsuessful Fthemes Fthumnils Frsh tutos FupdteEmngerEore FupdteEnotifier Futhority FxsessionEerrors
Cela ache tout le contenu du dossier, mme les chiers cachs. Un chier cach sous Linux est un chier qui commence par un point. Normalement, si vous vous trouvez dans votre rpertoire home, vous devriez avoir une bonne ope de chiers cachs. Ce sont en gnral des chiers de conguration de programmes.
Cette fois, pas le choix : si vous voulez mettre plusieurs paramtres longs, il faudra ajouter un espace entre chacun d'eux :
ommnde EEprmetreI EEprmetreP
On peut aussi combiner les paramtres longs et les paramtres courts dans une commande :
ommnde Edh EEutreprmetre
Il y a parfois deux critures possibles pour un paramtre de commande : une version courte et une version longue. Cela permet de vous laisser le choix selon que vous prfrez l'une ou l'autre. Notez que c'est la commande qui dcide des paramtres qu'elle accepte : il arrive parfois que certaines ne proposent pas le choix entre une version courte et une longue.
128
COMMANDES ET PARAMTRES
Testons cela sur la commande ls avec le paramtre --all, qui signie tout en anglais :
mteoPIdmteoPIEdesktopX~6 ls EEll F Fgonfd FmozillEthunderird FF FgimpEPFP Fnutilus Fshhistory FgksuFlok Fprofile Fshlogout Fgnome FreentlyEused Fshr FgnomeP FreentlyEusedFxel Fonfig FgnomePprivte Fssh hesktop FgstremerEHFIH Fsudosdminsuessful Fdmr FgtkrEIFPEgnomeP Fthemes Fesduth Fsgiuthority Fthumnils Fevolution Fions Frsh ixmples Flesshst tutos Ffe Flol FupdteEmngerEore Ffontonfig Fmromedi FupdteEnotifier Fgim Fmetity Futhority Fgonf Fmozill FxsessionEerrors
Comme vous le voyez, --all est un synonyme de -a. Ceci illustre ce que je vous disais l'instant, comme quoi parfois une commande propose deux faons d'utiliser un paramtre : une courte et une longue.
. . . cela indique que l'on associe la valeur 14 au paramtre p. Avec ce genre de technique, on peut par exemple faire comprendre l'ordinateur : Je veux voir la liste de tous les chiers de plus de 14 Mo . Si c'est un paramtre long, on fait en gnral comme ceci :
ommnde EEprmetreaIR
Le rsultat sera le mme, il est juste plus lisible mais aussi plus long crire. 129
CHAPITRE 9.
Autocompltion de commande
Le premier truc connatre, c'est l'autocompltion de commande. Prenons la commande date par exemple : vous tes un peu tte en l'air et vous ne savez plus comment elle s'crit. Par contre, vous tes srs des premires lettres de la commande.
En tapant deux fois sur Tabulation, vous avez demand l'ordinateur la liste des commandes qui commencent par da . On vous a rpondu dash et date . Il y 130
a donc deux commandes qui commencent par da , et vous venez de retrouver celle que vous cherchiez, c'est--dire date . Bien sympathique, l'ordinateur a rcrit l'invite de commandes en dessous ainsi que le dbut de la commande que vous aviez tape. Vous n'avez plus qu' complter avec les lettres te qui manquent et taper Entre, et ce sera bon. :-)
L'autocompltion
Plus sympa encore, s'il n'y a qu'un seul rsultat correspondant votre recherche, l'ordinateur compltera avec les lettres qui manquent et vous n'aurez plus qu' taper sur Entre ! Par exemple, il n'y a qu'une commande qui commence par dat . Tapez donc dat dans la console, puis appuyez une seule fois sur Tabulation. La commande se complte comme par magie.
Trop de commaaaandes !
Parfois, il y a trop de commandes correspondant votre recherche. Faites un essai un peu brutal : ne rentrez aucun dbut de commande et faites deux fois Tab (Tabulation). Cela demande de faire la liste de toutes les commandes disponibles sur votre ordinateur.
mteoPIdmteoPIEdesktopX~6 hisply ll PIUQ possiilitiesc @y or nA
Sauvage, n'est-ce pas ? Il y a 2 173 commandes disponibles sur mon ordinateur. Plus j'installerai de programmes, plus j'aurai de commandes utilisables. N'esprez donc pas toutes les connatre, de nouveaux programmes sortent tous les jours. cette question, vous pouvez rpondre y (yes ) et la liste s'achera page par page. Quelques raccourcis connatre quand une liste s'ache page par page : tapez Espace pour passer la page suivante ; tapez Entre pour aller la ligne suivante ; tapez q pour arrter la liste. Si vous rpondez n (no ), il ne se passera rien ; c'est dans le cas o vous vous diriez Ouh l, 2 173 possibilits : autant chercher une aiguille dans une botte de foin. . . je vais peut-tre aner ma recherche .
CHAPITRE 9.
Ce raccourci vaut de l'or : appuyez sur la che directionnelle Haut (gure 9.2) ; vous verrez apparatre la dernire commande que vous avez tape. Si vous appuyez de nouveau sur la che directionnelle Haut, vous verrez l'avant-dernire commande, puis l'avant-avant-dernire, etc.
La dernire commande tape sera toujours history, forcment. Vous remarquerez que les commandes sont numrotes : ainsi, on peut savoir que date est la 152e commande que j'ai tape dans le terminal.
Ctrl + R
Dans le cas o la che directionnelle Haut et la commande history ne suraient pas retrouver une vieille commande que vous avez tape, il y a un raccourci super utile : Ctrl + R. Appuyez donc sur les touches Ctrl et R en mme temps et l'ordinateur se mettra en mode recherche d'une commande tape ( R comme Recherche). 132
L, vous pouvez taper n'importe quelle suite de lettres correspondant une vieille commande. Par exemple, faites Ctrl + R puis tapez all . Linux retrouve la commande ls --all qui contenait justement le mot all . Vous n'avez plus qu' taper Entre pour relancer la commande ! :-)
@reverseEiEserhAll9X ls EEll
Si ce n'est pas la commande que vous cherchiez, appuyez nouveau sur Ctrl + R pour remonter dans la liste des commandes contenant all . a a peut-tre l'air bte sur une commande comme a, mais certaines sont vraiment trs longues et c'est un vrai bonheur de ne pas avoir les rcrire en entier !
133
CHAPITRE 9.
Ctrl + E : ramne le curseur la n de la ligne de commandes. La touche Fin a le mme eet. Ctrl + U : supprime tout ce qui se trouve gauche du curseur. Si celui-ci est situ la n de la ligne, cette dernire sera donc supprime. Ctrl + K : supprime tout ce qui se trouve droite du curseur. S'il est situ au dbut de la ligne, celle-ci sera donc totalement supprime. Ctrl + W : supprime le premier mot situ gauche du curseur. Un mot est spar par des espaces ; on s'en sert en gnral pour supprimer le paramtre situ gauche du curseur. Ctrl + Y : si vous avez supprim du texte avec une des commandes Ctrl + U, Ctrl + K ou Ctrl + W qu'on vient de voir, alors le raccourci Ctrl + Y collera le texte que vous venez de supprimer. C'est donc un peu comme un couper-coller. Nous allons arrter l la liste pour le moment. a vous fait dj pas mal de choses retenir. Il existe en fait beaucoup d'autres raccourcis clavier, mais je vous les montrerai au fur et mesure, quand nous en aurons besoin. Mme si c'est un peu fastidieux, je vous conseille de vous entraner les retenir par cur. Vous serez vraiment beaucoup plus ecaces lorsque vous les connatrez !
En rsum
La console ache une invite de commandes au dbut de la ligne. Cette invite rappelle votre nom d'utilisateur, le nom de la machine ainsi que le dossier dans lequel vous vous trouvez. On rentre des commandes dans la console pour demander l'ordinateur d'excuter des actions. Chaque commande peut tre complte de paramtres qui agissent comme des options pour modier l'action de la commande. Les paramtres sont gnralement constitus d'une lettre prcde d'un tiret (-a) ou de plusieurs lettres prcdes de deux tirets (all). Aprs avoir saisi les premires lettres d'une commande, on peut complter son nom l'aide de la touche Tabulation. On peut retrouver les commandes prcdentes l'aide des ches directionnelles Haut et Bas ou encore eectuer une recherche parmi les commandes prcdentes avec Ctrl + R. Il existe de nombreux autres raccourcis clavier qu'il est recommand de connatre pour pouvoir proter pleinement de la console.
134
Chapitre
10
Dicult :
hhh, les chiers sous Linux, tout un programme. Vous croyez savoir ce que sont les chiers et dossiers ? Vous croyez que votre disque dur s'appelle C: ? Que le lecteur CD c'est D: ou peut-tre E: ? Les choses ne fonctionnent pas du tout de la mme manire sous Linux et sous Windows. Or, savoir comment se dplacer de dossier en dossier et savoir lister les chiers, c'est quand mme sacrment important ! C'est pour cela que nous allons voir ensemble le fonctionnement des chiers sous Linux ds maintenant.
135
CHAPITRE 10.
Mais comment on fait pour savoir si le dossier dans lequel on est appartient au premier disque dur, au second disque dur, au lecteur CD. . . ? C'est le bazar, non ?
C'est ce qu'on pourrait croire au premier abord, mais en fait c'est juste une autre faon de penser la chose. ;-)
La racine
Dans un systme de chiers, il y a toujours ce qu'on appelle une racine, c'est--dire un gros dossier de base qui contient tous les autres dossiers et chiers . Sous Windows, il y a en fait plusieurs racines. C:\ est la racine de votre disque dur, D:\ est la racine de votre lecteur CD (par exemple). Sous Linux, il n'y a qu'une et une seule racine : / . Comme vous le voyez, il n'y a pas de lettre de lecteur car justement, Linux ne donne pas de nom aux lecteurs comme le fait Windows. Il dit juste La base, c'est / .
Il n'y a pas de dossier de plus haut niveau que /, c'est--dire qu'il n'existe pas de dossier qui contienne le dossier /. Quand on est la racine, on ne peut pas remonter en arrire car. . . on est dj tout au dbut.
136
Linux gre sans problme les noms de chiers et dossiers contenant des espaces, des accents et des majuscules. Toutefois, vous remarquerez que la plupart du temps on prfre les viter. On trouve ainsi plutt des noms tout en minuscules sans accents ni espaces, comme usr, bin, apache, etc. Souvenezvous qu'il n'est pas obligatoire de nommer vos chiers en suivant la mme rgle, mais la plupart des programmes que vous installerez prfrent utiliser des noms tout en minuscules sans espaces ni accents, ne soyez donc pas surpris.
Il n'est PAS ncessaire de retenir cette liste par cur. D'ailleurs je n'ai mis que les dossiers principaux, et elle est quand mme longue. Servez-vous-en juste si vous avez besoin de savoir quoi correspond grosso-modo tel ou tel dossier, mais ne vous en faites pas si vous ne matrisez pas fond le sens de chacun de ces dossiers.
bin : contient des programmes (excutables) susceptibles d'tre utiliss par tous les utilisateurs de la machine. boot : chiers permettant le dmarrage de Linux. dev : chiers contenant les priphriques. En fait on en reparlera plus tard ce dossier contient des sous-dossiers qui reprsentent chacun un priphrique. On y retrouve ainsi par exemple le chier qui reprsente le lecteur CD.
1. Et l'on ne risque pas de trouver de dossier qui s'appelle Windows !
137
CHAPITRE 10.
etc : chiers de conguration. home : rpertoires personnels des utilisateurs. On en a dj parl un peu avant : c'est dans ce dossier que vous placerez vos chiers personnels, la manire du dossier Mes documents de Windows. Chaque utilisateur de l'ordinateur possde son dossier personnel. Par exemple, dans mon cas mon dossier personnel se trouve dans /home/mateo21/. S'il y avait un autre utilisateur (appelons-le Patrick) sur mon ordinateur, il aurait eu droit lui aussi son propre dossier : /home/patrick/. lib : dossier contenant les bibliothques partages (gnralement des chiers .so) utilises par les programmes. C'est en fait l qu'on trouve l'quivalent des .dll de Windows. media : lorsqu'un priphrique amovible (comme une carte mmoire SD ou une cl USB) est insr dans votre ordinateur, Linux vous permet d'y accder partir d'un sous-dossier de media. On parle de montage. mnt : c'est un peu pareil que media, mais pour un usage plus temporaire. opt : rpertoire utilis pour les add-ons de programmes. proc : contient des informations systme. root : c'est le dossier personnel de l'utilisateur root . Normalement, les dossiers personnels sont placs dans home, mais celui de root fait exception. En eet, comme je vous l'ai dit dans le chapitre prcdent, root est le superutilisateur, le chef de la machine en quelque sorte. Il a droit un espace spcial. sbin : contient des programmes systme importants. tmp : dossier temporaire utilis par les programmes pour stocker des chiers. usr : c'est un des plus gros dossiers, dans lequel vont s'installer la plupart des programmes demands par l'utilisateur. var : ce dossier contient des donnes variables , souvent des logs (traces crites de ce qui s'est pass rcemment sur l'ordinateur). Cette liste de dossiers est en fait prsente sur tous les OS de type Unix, et pas seulement sous Linux. Encore une fois, ne retenez pas tout a. C'est juste pour vous donner une ide de ce que contiennent les dossiers la racine de Linux, car je sais que c'est une question qu'on se pose souvent quand on dbute.
pwd
Le nombre de dossiers et de chiers prsents aprs l'installation d'Ubuntu est tellement grand qu'il serait facile de s'y perdre. Un grand nombre de programmes sont en eet prinstalls pour que vous puissiez proter rapidement des possibilits de Linux. Ne 138
PWD
&
WHICH
: O. . . O SUIS-JE ?
pwd
Lorsque vous ouvrez la console pour la premire fois, Linux vous place dans votre dossier personnel, votre home. En l'occurrence dans mon cas, le dossier dans lequel je serai plac sera /home/mateo21. Normalement, l'invite de commandes vous indique le nom du dossier dans lequel vous vous trouvez :
mteoPIdmteoPIEdesktopX~6
Si vous vous souvenez bien, le nom du dossier est situ entre le : et le $ . Donc ici, on se trouve dans le dossier ~ .
Rappel : je l'ai dit dans le chapitre prcdent mais a ne fait pas de mal de le rpter, sous Linux le symbole ~ est un synonyme de votre dossier personnel. Chez moi cela signie donc /home/mateo21.
Cette indication de l'invite de commandes est pratique mais il faut savoir qu'il y a un autre moyen de connatre le nom du dossier actuel. C'est la commande pwd. pwd est l'abrviation de Print Working Directory , c'est--dire Acher le dossier actuel . C'est une commande trs simple qui ne prend aucun paramtre 2 , vous pouvez la tester :
2. On commence doucement, hein !
139
CHAPITRE 10.
Cela conrme bien ce que je vous disais : je me trouve en ce moment dans le dossier /home/mateo21 (gure 10.2).
which
Une commande n'est rien d'autre qu'un programme qu'on peut appeler n'importe quand et n'importe o dans la console.
La commande which prend un paramtre : le nom de la commande dont vous voulez connatre l'emplacement. Testons sur pwd :
mteoPIdmteoPIEdesktopX~6 whih pwd GinGpwd
Mme si cette commande ne nous est pas indispensable, j'ai pens que c'tait une bonne ide de vous la montrer ds le dbut an que vous puissiez vous familiariser un peu plus encore avec le systme de chiers de Linux. Alors, que fait cette commande ? Elle vous permet de localiser la position du programme correspondant une commande. Je m'explique : chaque commande sous Linux correspond un programme. Ainsi, pwd qu'on vient de voir est un programme.
pwd se trouve donc dans le dossier /bin/ ! Le pwd la n n'est pas un dossier mais le nom du programme lui-mme.
140
LS
Vous noterez que les programmes sous Linux ne possdent en gnral pas d'extension (contrairement Windows o l'extension utilise est en gnral .exe).
Tous les programmes ne sont pas situs dans un mme dossier. Pour vous en rendre compte, testez l'emplacement d'une autre commande. . . tenez, par exemple la commande which ! On va donc devoir crire which which dans la console 3 :
mteoPIdmteoPIEdesktopX~6 whih whih GusrGinGwhih
Cette fois, le programme ne se trouve pas dans /bin/ mais dans /usr/bin/ !
ls
ls est une des toutes premires commandes que nous avons essayes dans le chapitre
prcdent. Nous allons rentrer ici plus dans le dtail de son fonctionnement (et de ses nombreux paramtres. . .). Commenons par taper ls sans paramtre depuis notre dossier personnel 4 :
mteoPIdmteoPIEdesktopX~6 ls hesktop ixmples imges log tutos
Ubuntu active la coloration des chiers et dossiers par dfaut, vous devriez donc voir des couleurs chez vous. Les dossiers apparaissent en bleu fonc. Vous remarquerez que le dossier Examples est en bleu clair : cela signie que c'est un raccourci vers un dossier qui se trouve en fait ailleurs sur le disque.
Si la couleur ne s'ache pas, vous pouvez rajouter le paramtre --color=auto, comme ceci : ls --color=auto. Si vous ne voulez pas de la couleur au contraire, essayez le paramtre --color=none. Pour viter d'avoir taper chaque fois ce long paramtre, il faut modier un chier de conguration, mais on verra cela plus tard.
La commande ls accepte un grand nombre de paramtres. a ne sert rien que je vous fasse la liste complte ici (ce serait bien trop long) ; par contre, je vais vous faire dcouvrir les paramtres les plus utiles. a vous permettra de vous entraner utiliser et combiner des paramtres !
3. Oui, je sais, je suis un gros tordu. 4. Oui : j'ai cr quelques dossiers pour mon usage personnel, ne vous tonnez pas si vous n'avez pas les mmes.
141
CHAPITRE 10.
-a
Sous Linux, on peut cacher des chiers et dossiers. Ce n'est pas une protection, car on peut toujours les racher si on veut, mais a vite d'encombrer l'achage de la commande ls. Votre dossier home est un trs bon exemple car il est rempli de chiers et dossiers cachs. En ajoutant le paramtre -a, on peut voir tous ces chiers et dossiers cachs :
mteoPIdmteoPIEdesktopX~6 ls E F Fgnome FF FgnomeP Frmgetron FgnomePprivte Fshhistory Fgnomeprivte Fshlogout FgstremerEHFIH Fshr FgtkrEIFPEgnomeP Flender Fgweled Fonfig Fsgiuthority FhgyservermteoPIEdesktopH Fions FhgyservermteoPIEdesktopXH imges hesktop Finkspe Fdmr Fjv Femili Fjedit Fesduth Fkde Fevolution Flesshst ixmples Flgmes Ffe Flol Ffontonfig log Fgim Fmromedi Fgonf Fmop Fgonfd Fmopr Fgeny Fmetity FgimpEPFP Fmozill FgksuFlok FmozillEthunderird Fnnohistory Fnutilus FopenoffieForgP FpgdminQ Fpgpss Fprofile Fqt FreentlyEused FreentlyEusedFxel Fssh Fsudosdminsuess Fthemes Fthumnils Frsh Ftslient tutos FupdteEmngerEore FupdteEnotifier Fvl Fwormux Futhority Fxine FxsessionEerrors
Vous comprenez peut-tre mieux maintenant pourquoi tous ces chiers et dossiers sont cachs : c'est encombrant. Certains lments commenant par un point . sont des dossiers, d'autres sont des chiers. La meilleure faon de faire la distinction est de comparer les couleurs : les dossiers en bleu, le reste dans la couleur par dfaut (par exemple, le blanc ou le noir). Les deux premiers lments sont assez intrigants : . et .. . Le premier reprsente en fait le dossier actuel, et .. reprsente le dossier parent, c'est--dire le dossier prcdent dans l'arborescence. Par exemple, l je suis dans /home/mateo21, .. reprsente donc le dossier /home.
Le paramtre -A (un A majuscule au lieu d'un a minuscule) a pratiquement la mme signication : cela ache la mme chose sauf ces lments . et .. . Comme quoi il faut faire attention aux majuscules !
142
LS
-F
Ce paramtre est surtout utile pour ceux qui n'ont pas ach la couleur dans la console (ou n'en veulent pas). Il rajoute la n des lments un symbole pour qu'on puisse faire la distinction entre les dossiers, chiers, raccourcis. . .
mteoPIdmteoPIEdesktopX~6 ls Ep hesktopG ixmplesd imgesG logG tutosG
Grce a on peut voir que tous les lments sont des dossiers, sauf Examples qui est un raccourci (d'o la prsence du @).
-l
: liste dtaille
Le paramtre -l (la lettre L en minuscule) est un des plus utiles. Il ache une liste dtaillant chaque lment du dossier :
mteoPIdmteoPIEdesktopX~6 ls El totl IT drwxrExrEx P mteoPI mteoPI RHWT lrwxrwxrwx I mteoPI mteoPI PT Eb GusrGshreGexmpleEontent drwxrExrEx P mteoPI mteoPI RHWT drwxrExrEx Q mteoPI mteoPI RHWT drwxrExrEx Q mteoPI mteoPI RHWT
PHHUEHWEPR IUXPP hesktop PHHUEHWEIW IVXQI ixmples PHHUEHWEPS ISXIU imges PHHUEHWEPS IIXII log PHHUEHWEIW IWXSI tutos
Il y a un lment par ligne. Chaque colonne a sa propre signication. De gauche droite : 1. droits sur le chier (on fera un chapitre entier pour expliquer comment fonctionnent les droits sous Linux) ; 2. nombre de liens physiques (cela ne nous intresse pas ici) ; 3. nom de la personne propritaire du chier (l, c'est moi !). Si le chier avait t cr par quelqu'un d'autre, par exemple Patrick, on aurait vu son nom la place ; 4. groupe auquel appartient le chier (on en reparlera dans le chapitre sur les droits). Il se peut que le nom du groupe soit le mme que celui du propritaire ; 5. taille du chier, en octets ; 6. date de dernire modication ; 7. nom du chier (ou dossier).
Vous noterez aussi que dans le cas du raccourci (on parle de lien symbolique), la commande nous prcise vers o pointe le raccourci (en l'occurrence /usr/share/example-content).
143
CHAPITRE 10.
-h
Quand on fait un ls -l, la taille est ache en octets. Seulement, ce n'est parfois pas trs lisible. Par exemple :
mteoPIdmteoPIEdesktopX~Gixmples6 ls El totl WSHH ErwErEErEE I root root QSUTPWT PHHUEHREHQ ErwErEErEE I root root PPWTUR PHHUEHREHQ ErwErEErEE I root root VRVHIQ PHHUEHREHQ ErwErEErEE I root root IIVTPIW PHHUEHREHQ ErwErEErEE I root root RUSVR PHHUEHREHQ
Si vous rajoutez le paramtre h ( h pour Human Readable, c'est--dire lisible par un humain ), vous obtenez des tailles de chiers beaucoup plus lisibles (normal, vous tes des humains) :
mteoPIdmteoPIEdesktopX~Gixmples6 ls totl WDQw ErwErEErEE I root root QDSw PHHUEHREHQ ErwErEErEE I root root PPSu PHHUEHREHQ ErwErEErEE I root root VPWu PHHUEHREHQ ErwErEErEE I root root IDPw PHHUEHREHQ ErwErEErEE I root root RUu PHHUEHREHQ Elh IUXHS IUXHS IUXHS IUXHS IUXHS ixperiene uuntuFogg flesHIHIesopFspx gimpEuuntuEsplshFxf kuuntuElefletFpng logoEiduuntuFpng
Grce a, on voit alors bien que le chier Experience ubuntu.ogg fait 3,5 Mo, logo-Edubuntu.png fait 47 Ko, etc.
-t
Voil une option dont l'intrt est sous-estim ! -t permet en eet de trier par date de dernire modication, au lieu de trier par ordre alphabtique comme cela est fait par dfaut. On voit ainsi en premier le dernier chier que l'on a modi, et en dernier celui auquel on n'a pas touch depuis le plus longtemps :
mteoPIdmteoPIEdesktopX~6 ls Elt totl IT drwxrExrEx P mteoPI mteoPI RHWT drwxrExrEx Q mteoPI mteoPI RHWT drwxrExrEx P mteoPI mteoPI RHWT drwxrExrEx Q mteoPI mteoPI RHWT lrwxrwxrwx I mteoPI mteoPI PT Eb GusrGshreGexmpleEontent
144
LS
De toute vidence, le dernier chier (ici, c'est un dossier) modi est images . En revanche, comme je n'ai jamais touch Examples , il est normal qu'il apparaisse en dernier. En pratique, je combine -t avec -r qui renverse l'ordre d'achage des chiers. Je prfre en eet avoir le dernier chier modi en bas de la liste, c'est plus pratique l'usage dans la console. Et comme je suis un gros bourrin, je combine un peu tous les paramtres que l'on vient de voir, ce qui donne un beau ls -larth qui contient toutes les options que j'aime. ;-)
mteoPIdmteoPIEdesktopX~6 ls Elrth totl QVHu ErwEEEEEEE I mteoPI mteoPI PT PHHUEHWEIW ErwErEErEE I mteoPI mteoPI VW PHHUEHWEIW ErwEEEEEEE I mteoPI mteoPI IT PHHUEHWEIW drwxEEEEEE P mteoPI mteoPI RDHu PHHUEHWEIW lrwxrwxrwx I mteoPI mteoPI PT PHHUEHWEIW Eb GusrGshreGexmpleEontent ErwErEErEE I mteoPI mteoPI PPH PHHUEHWEIW drwxrExrEx R root root RDHu PHHUEHWEIW drwxrExrEx IH mteoPI mteoPI RDHu PHHUEHWEPS ErwErEErEE I mteoPI mteoPI IDIu PHHUEHWEPS drwxrExrEx RU mteoPI mteoPI RDHu PHHUEHWEPS ErwEEEEEEE I mteoPI mteoPI IDVu PHHUEHWEPS ErwEEEEEEE I mteoPI mteoPI IUu PHHUEHWEPS drwxEEEEEE P mteoPI mteoPI RDHu PHHUEHWEPS ErwEEEEEEE I mteoPI mteoPI QW PHHUEHWEPS ErwErEErEE I mteoPI mteoPI SQu PHHUEHWEPS
ITXRH ITXRH ITXRH ITXRH IVXQI IVXQI IVXQI ITXHQ ITXHQ ITXHQ ITXQV ITXSP ITXSR IUXIV IUXPI
Fdmr FgtkrEIFPEgnomeP Fesduth FupdteEnotifier ixmples Fshlogout FF Fjedit FpgdminQ F Fshhistory FreentlyEused Fgonfd Flesshst FxsessionEerrors
Note : j'ai volontairement rduit cette liste car il y a beaucoup de chiers dans mon home. En pratique la liste est beaucoup plus grande.
Le chier cach .xsession-errors est donc le dernier qui a t modi dans ce dossier sur mon ordinateur.
Plutt que d'avoir rcrire ls -larth chaque fois (c'est un peu long), on peut crer un alias, c'est--dire une commande synonyme. Par exemple, j'ai cr l'alias ll (deux fois L ) qui est automatiquement transform par Linux en ls -larth. On verra comment crer des alias lorsqu'on saura se servir d'un diteur de chiers.
145
CHAPITRE 10.
cd
: changer de dossier
Bon : mine de rien, depuis tout l'heure on est coinc dans notre dossier home et on aimerait bien bouger de l. Le moment est venu de dplacer le navire, moussaillon ! La commande que nous allons tudier ici s'appelle cd, abrviation de Change Directory (changer de dossier). C'est une commande trs importante que vous allez utiliser quelques milliers de fois dans votre vie (au moins). Contrairement ls, la commande cd ne prend pas plein de paramtres mais juste un seul : le nom du dossier dans lequel vous souhaitez aller. Si on veut aller la racine, il sut de taper cd / :
mteoPIdmteoPIEdesktopX~6 d G mteoPIdmteoPIEdesktopXG6 pwd G
Aprs avoir tap cd /, on se retrouve la racine. L'invite de commandes a chang et le ~ a t remplac par un /. Si vous tes sceptiques, un petit coup de pwd devrait vous conrmer que vous tes bien dans /. Bien ! Listons les chiers et dossiers contenus dans / :
mteoPIdmteoPIEdesktopXG6 ls Ep inG devG initrdG liG mntG ootG etG initrdFimgd lostCfoundG optG dromd homeG initrdFimgFoldd mediG proG rootG sysG vrG sinG tmpG vmlinuzd srvG usrG vmlinuzFoldd
Vous y retrouvez un grand nombre de dossiers que je vous ai dcrits au dbut du chapitre. Allons dans le sous-dossier usr :
mteoPIdmteoPIEdesktopXG6 d usr
Chez moi, il n'y a que des dossiers. Hummm, le dossier games m'intrigue, voyons voir ce que j'ai comme jeux :
mteoPIdmteoPIEdesktopXGusr6 d gmes mteoPIdmteoPIEdesktopXGusrGgmes6
146
CD
: CHANGER DE DOSSIER
147
CHAPITRE 10.
Eh mais en fait, il y a plusieurs faons d'aller dans un dossier, non ? Tout l'heure, on est all la racine en tapant cd /, et maintenant en tapant cd ../.. C'est quoi cette aaire ?
Il y a en fait deux faons de changer de dossier : en indiquant un chemin relatif, ou en indiquant un chemin absolu.
En faisant cela, on utilise un chemin relatif, c'est--dire relatif au dossier actuel. Quand on met juste le nom d'un dossier comme ici, cela indique que l'on veut aller dans un sous-dossier. Si on fait cd games depuis la racine, a va planter :
mteoPIdmteoPIEdesktopXG6 d gmes shX dX gmesX euun fihier ou rpertoire de e type
Je crois que le message d'erreur est assez clair : il n'y a aucun dossier games dans /. Pour se rendre dans games, il faut d'abord indiquer le dossier qui le contient (usr) :
mteoPIdmteoPIEdesktopXG6 d usrGgmes mteoPIdmteoPIEdesktopXGusrGgmes6
148
CD
: CHANGER DE DOSSIER
Ce qui signie reviens en arrire (donc dans /home) puis reviens en arrire (donc dans /), puis va en avant dans usr, puis va en avant dans games . Voyez en gure 10.6.
CHAPITRE 10.
Un chemin absolu est donc facile reconnatre, car on part toujours de la racine /. Un chemin relatif peut aussi s'avrer trs pratique et plus court (a dpend des cas). Ce sera vous de choisir chaque fois comment vous voulez crire votre chemin. Vous avez le choix.
La maligne : plus court et plus pratique, vous pouvez utiliser l'alias ~ qui signie la mme chose. Cela donne :
mteoPIdmteoPIEdesktopXGusrGgmes6 d ~ mteoPIdmteoPIEdesktopX~6
La super maligne : si vous ne mettez aucun paramtre la commande cd, a vous ramne aussi dans votre rpertoire personnel.
mteoPIdmteoPIEdesktopXGusrGgmes6 d mteoPIdmteoPIEdesktopX~6
Autocompltion du chemin
Cette astuce est vitale ; si vous ne vous en servez pas, vous passez ct d'une des plus importantes astuces de la console. L'ide est simple : taper cd /usr/games/trucbidule c'est bien, mais c'est parfois un peu long de tout crire. On a la emme. Vous avez la emme. Oui, vous. Alors vous allez justement demander l'ordinateur de complter le chemin tout seul ! L'autocompltion de chemin fonctionne de la mme manire que l'autocompltion de commande qu'on a vue dans le chapitre prcdent : avec la touche Tab (Tabulation). Faites le test avec moi. Commencez par vous placer dans /usr : 150
DU
Tapez ensuite juste cd ga, puis appuyez sur Tab. C'est magique, le nom du dossier a t automatiquement complt !
mteoPIdmteoPIEdesktopXGusr6 d gmesG
Revenez maintenant dans /usr (en faisant cd .. par exemple) et essayez de taper juste cd l, puis faites Tab. Rien ne se passe : cela signie que l'ordinateur n'a pas trouv de dossier qui corresponde au dbut de votre recherche, ou alors qu'il y en plusieurs qui commencent par l . Faites nouveau Tab :
mteoPIdmteoPIEdesktopXGusr6 d l liG lolG mteoPIdmteoPIEdesktopXGusr6 d l
On vient de vous donner la liste des dossiers qui commencent par l ! Cela signie qu'il faut prciser votre recherche parce que sinon, l'ordinateur ne peut pas deviner dans quel dossier vous voulez entrer. a tombe bien, la commande a t rcrite en dessous, vous n'avez plus qu' ajouter une lettre plus prcise : par exemple o pour que Linux devine que vous voulez aller dans le dossier local. Tapez donc o , puis nouveau Tab, et le nom sera complt !
mteoPIdmteoPIEdesktopXGusr6 d lolG
Faites des tests pour vous entraner utiliser l'autocompltion, c'est vraiment trs important. Vous allez voir, c'est intuitif et vraiment pratique !
du
La commande du , pour Disk Usage (utilisation du disque) vous donne des informations sur la taille qu'occupent les dossiers sur votre disque. Placez-vous pour commencer dans /usr/games, et tapez du :
mteoPIdmteoPIEdesktopX~6 d GusrGgmes mteoPIdmteoPIEdesktopXGusrGgmes6 du SUQP F
151
CHAPITRE 10.
Comme ce dossier ne contient pas de sous-dossier, la commande du nous renvoie la taille totale que font les chiers contenus dans le dossier. Si vous allez dans votre home en revanche, celui-ci contient beaucoup de sous-dossiers. Dans ce cas, la commande du va renvoyer la taille de chacun des sous-dossiers, puis la taille totale la n ( . ) :
mteoPIdmteoPIEdesktopXGusrGgmes6 d mteoPIdmteoPIEdesktopX~6 du RHH FGFrsh R FGFthemes QP FGFmozillEthunderirdGVvywTpqoFdefultGwilGvol polders QT FGFmozillEthunderirdGVvywTpqoFdefultGwil IP FGFmozillEthunderirdGVvywTpqoFdefultG FFF FFF PTR FGFjeditGjrs R FGFjeditGmros QVH FGFjeditGsettingsEkup VST FGFjedit VPRVR F
-h
Ce qui est bien, c'est que les commandes reprennent souvent les mmes paramtres. Ainsi, on avait vu -h pour ls, eh bien ce paramtre est le mme pour avoir des tailles humaines avec du !
mteoPIdmteoPIEdesktopX~6 du Eh RHHu FGFrsh RDHu FGFthemes QPu FGFmozillEthunderirdGVvywTpqoFdefultGwilGvol polders QTu FGFmozillEthunderirdGVvywTpqoFdefultGwil IPu FGFmozillEthunderirdGVvywTpqoFdefultG FFF FFF PTRu FGFjeditGjrs RDHu FGFjeditGmros QVHu FGFjeditGsettingsEkup VSTu FGFjedit VIw F
152
DU
Mon dossier home prend donc 81 Mo d'espace disque, son sous-dossier cach .jedit prend 856 Ko, etc.
-a
Par dfaut, du n'ache que la taille des dossiers. Pour avoir aussi la taille des chiers qu'ils contiennent, rajoutez l'option -a (all ) :
mteoPIdmteoPIEdesktopX~6 du Eh FFF VDHu FGFjeditGsettingsEkupGrevs~S~ PRu FGFjeditGsettingsEkupGhistory~I~ VDHu FGFjeditGsettingsEkupGrevs~R~ QVHu FGFjeditGsettingsEkup RRu FGFjeditGpluginwgrEghedFxmlFgz VSTu FGFjedit VIw F
-s
Pour n'avoir que l'espace total occup par le dossier et donc ne pas acher le dtail des sous-dossiers, utilisez -s (que je combine -h pour plus de lisibilit) :
mteoPIdmteoPIEdesktopX~6 du Esh VIw F
Je vois ainsi que mon dossier home fait 81 Mo (rappel : le symbole point . signie le dossier actuel ).
En rsum
Sous Linux, tout est organis sous forme de chiers. Il n'y a pas de lecteur du type C: comme sous Windows. Les dossiers sont imbriqus entre eux partir du dossier parent principal /. On l'appelle la racine. Le dossier dans lequel les utilisateurs stockent leurs documents est /home. Si votre login est patrick, alors votre dossier personnel sera /home/patrick. La commande pwd permet de savoir en console dans quel dossier on se situe. ls ache la liste des chiers prsents dans le dossier actuel. cd permet de changer de dossier.
153
CHAPITRE 10.
154
Chapitre
11
Dicult :
prs avoir vu comment taient organiss les chiers sous Linux, nous allons apprendre les manipuler ! Par exemple, comment faire pour acher le contenu d'un chier ? Comment le dplacer, le copier, le supprimer ? C'est donc un chapitre la fois simple et riche qui vous attend, tout au long duquel vous allez apprendre beaucoup de nouvelles commandes basiques de Linux qu'il vous faut connatre absolument !
155
CHAPITRE 11.
cat
Nous allons d'abord voir comment acher le contenu d'un chier. Il y a en gros deux commandes basiques sous Linux qui permettent de faire cela : cat ; less. Aucune de ces commandes ne permet d'diter un chier, elles permettent juste de le voir. Nous tudierons l'dition plus tard, a mrite au moins un chapitre entier.
Mais. . . pourquoi deux commandes pour acher un chier ? Une seule n'aurait pas su ?
En fait, chacune a ses spcicits ! Nous allons les voir dans le dtail. Pour nos exemples, nous allons travailler sur un chier qui existe dj : syslog. Il se trouve dans le dossier /var/log. Commencez par vous y rendre :
mteoPIdmteoPIEdesktopX~6 d GvrGlog
Ce dossier contient plusieurs chiers de log, c'est--dire des chiers qui gardent une trace de l'activit de votre ordinateur. Vous pouvez en faire la liste si vous le voulez, en tapant ls :
mteoPIdmteoPIEdesktopXGvrGlog6 pid demonFlogFH pidFIFgz demonFlogFIFgz pidFPFgz demonFlogFPFgz pidFQFgz demonFlogFQFgz pidFRFgz deug pprmor deugFH pportFlog deugFIFgz pportFlogFI deugFPFgz pportFlogFPFgz deugFQFgz pportFlogFQFgz distEupgrde pportFlogFRFgz dmesg pportFlogFSFgz dmesgFH pt dmesgFIFgz uthFlog dmesgFPFgz uthFlogFH dmesgFQFgz uthFlogFIFgz dmesgFRFgz uthFlogFPFgz dpkgFlog uthFlogFQFgz dpkgFlogFI ittorrent dpkgFlogFPFgz oot fillog ootstrpFlog fontonfigFlog ls kernFlogFH kernFlogFIFgz kernFlogFPFgz kernFlogFQFgz lstlog lprFlog milFerr milFinfo milFlog milFwrn messges messgesFH messgesFIFgz messgesFPFgz messgesFQFgz news populrityEontest populrityEontestFH populrityEontestFIFgz populrityEontestFPFgz populrityEontestFQFgz srollkeeperFlogFP syslog syslogFH syslogFIFgz syslogFPFgz syslogFQFgz syslogFRFgz syslogFSFgz syslogFTFgz udev unttendedEupgrdes userFlog userFlogFH userFlogFIFgz userFlogFPFgz userFlogFQFgz uupFlog wtmp wtmpFI wvdilonfFlog orgFHFlog
156
CAT
tmp tmpFI ups demonFlog fsk gdm instller kernFlog
&
LESS
: AFFICHER UN FICHIER
orgFHFlogFold
Le chier sur lequel nous allons travailler, syslog, contient des informations de log de ce qui s'est pass rcemment sur l'ensemble de votre ordinateur.
Vous noterez qu'il est frquent de voir des chiers sans extension sous Linux. Notre chier s'appelle syslog tout court, et non pas syslog.txt ou syslog.log comme on pourrait avoir l'habitude de le voir sous Windows. Un chier sans extension peut tre ouvert et lu sans aucun problme comme n'importe quel autre chier.
cat
La commande cat permet d'acher tout le contenu d'un chier dans la console d'un coup. Il vous sut d'indiquer en paramtre le nom du chier que vous voulez acher, en l'occurrence syslog :
mteoPIdmteoPIEdesktopXGvrGlog6 t syslog xov IR HHXRRXPQ mteoPIEdesktop syslogd IFRFI5PIuuntuQX restrtF xov IR HHXRRXPQ mteoPIEdesktop nronTUPSX to ronFdily9 terminted xov IR HHXRRXPQ mteoPIEdesktop nronTUPSX xorml exit @I jo runA xov IR HHXRRXPS mteoPIEdesktop xetworkwngerX `infob ethIX link timed outF xov IR HHXRRXSI mteoPIEdesktop xetworkwngerX `infob ethIX link timed outF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `deugb IIWRWWUSHVFQQPHWQ nmdevieVHPIIwirelessgettivtionp@AX poring e 9sps9 xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob ser withX GorgGfreedesktopGxetworkwngerGheviesGethI G sps xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob hetivting devie ethIF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIAX nellingFFF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIA nelltion hndler sheduledFFF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIAX witing for devie to nel tivtionF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIA nelltion hndledF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIAX nelledF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob X sending ommnd 9hsefvixiyu H9 xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob X response ws 9yu9 xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob X sending ommnd
157
CHAPITRE 11.
9egex H9 xov IR HHXRSXIT mteoPIEdesktop xetworkwngerX nmtrequestgetpX ssertion req 3a xvv9 filed xov IR HHXRSXIT mteoPIEdesktop xetworkwngerX nmtrequestgetstgeX ssertion req 3a xvv9 filed xov IR HHXRSXIT mteoPIEdesktop xetworkwngerX `infob ethIX link timed outF xov IR HHXRSXPI mteoPIEdesktop xetworkwngerX nmtrequestgetpX ssertion req 3a xvv9 filed xov IR HHXRSXPI mteoPIEdesktop xetworkwngerX pisuthrequiredX ssertion p 3a xvv9 filed xov IR HHXRSXPI mteoPIEdesktop xetworkwngerX `infob etivtion @ethIGwirelessAX ssoition took too long @bIPHsAD sking for new keyF xov IR HHXRSXPI mteoPIEdesktop xetworkwngerX nmdusgetuserkeyfornetwork ssertion req 3a xvv9 filed xov IR HHXRUXRS mteoPIEdesktop initX ttyR min proess @RSIUA killed y iw signl xov IR HHXRUXRS mteoPIEdesktop initX ttyS min proess @RSIVA killed y iw signl xov IR HHXRUXRS mteoPIEdesktop initX ttyP min proess @RSPHA killed y iw signl xov IR HHXRUXRS mteoPIEdesktop initX ttyQ min proess @RSPPA killed y iw signl xov IR HHXRUXRS mteoPIEdesktop initX ttyI min proess @RSPRA killed y iw signl xov IR HHXRUXRS mteoPIEdesktop initX ttyT min proess @RSPSA killed y iw signl xov IR HHXRUXRT mteoPIEdesktop vhiEdemonSQWHX qot sqiwD quittingF xov IR HHXRUXRV mteoPIEdesktop exiting on signl IS xov IR HHXRVXRP mteoPIEdesktop syslogd IFRFI5PIuuntuQX restrtF
FFF
Comme le chier est trs gros (il fait plusieurs centaines de lignes), je n'ai pas copi tout ce qui s'est ach dans ma console. Ne vous tonnez pas si vous voyez tout s'acher d'un coup : c'est normal, c'est le but. La commande cat vous envoie tout le chier la gure. Elle est plus adapte lorsque l'on travaille sur de petits chiers que sur des gros, car dans un cas comme celui-l, on n'a pas le temps de lire tout ce qui s'ache l'cran. Il y a peu de paramtres vraiment intressants utiliser avec la commande cat, car c'est une commande somme toute trs basique. On notera quand mme le paramtre -n qui permet d'acher les numros de ligne :
mteoPIdmteoPIEdesktopXGvrGlog6 t En syslog I xov IR HHXRRXPQ mteoPIEdesktop syslogd IFRFI5PIuuntuQX restrtF P xov IR HHXRRXPQ mteoPIEdesktop nronTUPSX to ronFdily9 terminted Q xov IR HHXRRXPQ mteoPIEdesktop nronTUPSX
158
CAT
&
LESS
: AFFICHER UN FICHIER
xorml exit @I jo runA R xov IR HHXRRXPS mteoPIEdesktop xetworkwngerX `infob ethIX link timed outF S xov IR HHXRRXSI mteoPIEdesktop xetworkwngerX `infob ethIX link timed outF T xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `deugb IIWRWWUSHVFQQPHWQ FFF
less
La commande cat est rapide. Trop rapide. Tout le chier est lu et ach d'un coup dans la console, ce qui fait que l'on n'a pas le temps de le lire s'il est trs gros. C'est l qu'une autre commande comme less devient vraiment indispensable. La grosse dirence entre less et cat, c'est que less ache progressivement le contenu du chier, page par page. a vous laisse le temps de le lire dans la console. :-)
Notez qu'il existe aussi une commande trs proche : more. Pour faire simple, la dirence entre more et less c'est que more est vieux et possde peu de fonctionnalits, tandis que less est beaucoup plus puissant et rapide. Bref, utilisez less, mais si vous voyez un jour quelqu'un utiliser more, ne soyez pas surpris.
Comment a marche ? Eh bien la commande est trs simple : less nomdufichier.
mteoPIdmteoPIEdesktopXGvrGlog6 less syslog xov IR HHXRRXPQ mteoPIEdesktop syslogd IFRFI5PIuuntuQX restrtF xov IR HHXRRXPQ mteoPIEdesktop nronTUPSX to ronFdily9 terminted xov IR HHXRRXPQ mteoPIEdesktop nronTUPSX xorml exit @I jo runA xov IR HHXRRXPS mteoPIEdesktop xetworkwngerX `infob ethIX link timed outF xov IR HHXRRXSI mteoPIEdesktop xetworkwngerX `infob ethIX link timed outF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `deugb IIWRWWUSHVFQQPHWQ nmdevieVHPIIwirelessgettivtionp@AX poring e 9sps9 xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob ser withX GorgGfreedesktopGxetworkwngerGheviesGethI G sps xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob hetivting devie ethIF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIAX nellingFFF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIA nelltion hndler sheduledFFF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIAX witing for devie to nel tivtionF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIA nelltion hndledF
159
CHAPITRE 11.
xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob nelledF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob 9hsefvixiyu H9
Ce qui est intressant pour nous ici, c'est que la commande less a arrt la lecture du chier au bout de quelques lignes (la taille d'un cran de console). Cela vous laisse le temps de lire le dbut du chier. On n'a lu pour le moment que les toutes premires lignes du chier.
La casse des caractres est importante. Ainsi, si je vous dis qu'il faut appuyer sur la touche d , ce n'est pas un D majuscule (si vous essayez, vous verrez que a ne fonctionne pas). Sous Linux, on fait souvent la dirence entre majuscules et minuscules : souvenez-vous-en !
Si on tape Espace, on avance donc d'un cran dans le chier :
xov IR HHXRUXRS mteoPIEdesktop initX ttyR min proess @RSIUA killed y iw signl xov IR HHXRUXRS mteoPIEdesktop initX ttyS min proess @RSIVA killed y iw signl xov IR HHXRUXRS mteoPIEdesktop initX ttyP min proess @RSPHA killed y
160
CAT
&
LESS
: AFFICHER UN FICHIER
iw signl xov IR HHXRUXRS mteoPIEdesktop initX ttyQ min proess @RSPPA killed y iw signl xov IR HHXRUXRS mteoPIEdesktop initX ttyI min proess @RSPRA killed y iw signl xov IR HHXRUXRS mteoPIEdesktop initX ttyT min proess @RSPSA killed y iw signl xov IR HHXRUXRT mteoPIEdesktop vhiEdemonSQWHX qot sqiwD quittingF xov IR HHXRUXRV mteoPIEdesktop exiting on signl IS xov IR HHXRVXRP mteoPIEdesktop syslogd IFRFI5PIuuntuQX restrtF xov IR HHXRVXRP mteoPIEdesktop kernelX snspeting GootGystemFmpEPFTFPPEIREgeneri xov IR HHXRVXRP mteoPIEdesktop kernelX voded PSRRS symols from GootGystemFmpEPFTFPPEIREgeneriF xov IR HHXRVXRP mteoPIEdesktop kernelX ymols mth kernel version PFTFPPF xov IR HHXRVXRP mteoPIEdesktop kernelX xo module symols loded E kernel modules not enledF xov IR HHXRVXRP mteoPIEdesktop kernelX HFHHHHHH vinux version PFTFPPEIREgeneri @uildddplmerA @g version RFIFQ PHHUHWPW @prereleseA
161
CHAPITRE 11.
head
Eh oui. Et gurez-vous que celles-l aussi valent le coup d'tre connues. Comme quoi on en fait des commandes, rien que pour lire un chier ! Ces deux commandes sont un peu l'oppos l'une de l'autre : la premire permet d'acher le dbut du chier, la seconde permet d'acher la n.
head
La commande head ( tte en anglais) ache seulement les premires lignes du chier. Elle ne permet pas de se dplacer dans le chier comme less, mais juste de rcuprer les premires lignes.
mteoPIdmteoPIEdesktopXGvrGlog6 hed syslog xov IR HHXRRXPQ mteoPIEdesktop syslogd IFRFI5PIuuntuQX restrtF xov IR HHXRRXPQ mteoPIEdesktop nronTUPSX to ronFdily9 terminted xov IR HHXRRXPQ mteoPIEdesktop nronTUPSX xorml exit @I jo runA xov IR HHXRRXPS mteoPIEdesktop xetworkwngerX `infob ethIX link timed outF xov IR HHXRRXSI mteoPIEdesktop xetworkwngerX `infob ethIX link timed outF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `deugb IIWRWWUSHVFQQPHWQ nmdevieVHPIIwirelessgettivtionp@AX poring e 9sps9 xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob ser withX GorgGfreedesktopGxetworkwngerGheviesGethI G sps xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob hetivting devie ethIF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIAX nellingFFF xov IR HHXRSXHV mteoPIEdesktop xetworkwngerX `infob etivtion @ethIA nelltion hndler sheduledFFF
Si vous avez juste besoin de rcuprer les premires lignes d'un chier, head est donc la commande qu'il vous faut. Simple, net, ecace. Comment ? Vous voulez des paramtres ? Je n'en ai pas beaucoup vous orir, mais celui-l au moins est connatre : -n, suivi d'un nombre. Il permet d'acher le nombre de lignes que vous voulez. Par exemple, si vous ne voulez que les trois premires lignes, tapez :
mteoPIdmteoPIEdesktopXGvrGlog6 hed En Q syslog xov IR HHXRRXPQ mteoPIEdesktop syslogd IFRFI5PIuuntuQX restrtF xov IR HHXRRXPQ mteoPIEdesktop nronTUPSX to ronFdily9 terminted xov IR HHXRRXPQ mteoPIEdesktop nronTUPSX xorml exit @I jo runA
162
HEAD
&
TAIL
Et voil le travail !
tail
: acher la n du chier
Trs intressante aussi (voire mme plus), la commande tail vous renvoie la n du chier, donc les dernires lignes.
mteoPIdmteoPIEdesktopXGvrGlog6 til syslog xov IR PPXRPXIH mteoPIEdesktop xetworkwngerX `infob glering nsd hosts heF xov IR PPXRPXIH mteoPIEdesktop xetworkwngerX `exb nmspwnproess@AX nmspwnproess@9GusrGsinGnsd Ei hosts9AX ould not spwn proessF @piled to exeute hild proess 4GusrGsinGnsd4 @xo suh file or diretoryAA xov IR PPXRPXIH mteoPIEdesktop xetworkwngerX `infob etivtion @ethIA pinish hndler sheduledF xov IR PPXRPXIH mteoPIEdesktop xetworkwngerX `infob etivtion @ethIA tge S of S @s gonfigure gommitA ompleteF xov IR PPXRPXIH mteoPIEdesktop xetworkwngerX `infob etivtion @ethIA suessfulD devie tivtedF xov IR PPXRIXSU mteoPIEdesktop ntpdteVRPPX step time server WIFIVWFWRFR offset EIQFRHIRSI se xov IR PPXRIXSW mteoPIEdesktop vhiEdemonSQVSX egistering new ddress reord for feVHXXPIWXdPffXfeTIXWHH on ethIFBF xov IR PPXRPXHV mteoPIEdesktop kernelX UVUHFITHHHH ethIX no svT routers present xov IR PQXIIXPT mteoPIEdesktop EE weu EE xov IR PQXIUXHI mteoPIEdesktop GGfsxGgyxVSISX @rootA gwh @ d G 88 runEprts EEreport GetGronFhourlyA
On peut l encore utiliser -n suivi d'un nombre pour acher les x dernires lignes :
mteoPIdmteoPIEdesktopXGvrGlog6 til En Q syslog xov IR PPXRPXHV mteoPIEdesktop kernelX UVUHFITHHHH ethIX no svT routers present xov IR PQXIIXPT mteoPIEdesktop EE weu EE xov IR PQXIUXHI mteoPIEdesktop GGfsxGgyxVSISX @rootA gwh @ d G 88 runEprts EEreport GetGronFhourlyA
Mais ce n'est pas tout ! Il y a un autre paramtre ct duquel vous ne pouvez pas passer : -f (f pour follow, suivre en anglais). Ce paramtre magique ordonne tail de suivre la n du chier au fur et mesure de son volution. C'est extrmement utile pour suivre un chier de log qui volue souvent. Vous pouvez tester sur syslog par exemple : 163
CHAPITRE 11.
mteoPIdmteoPIEdesktopXGvrGlog6 til Ef syslog xov IR PQXIIXPT mteoPIEdesktop EE weu EE xov IR PQXIUXHI mteoPIEdesktop GGfsxGgyxVSISX @rootA gwh @ d G 88 runEprts EEreport GetGronFhourlyA xov IR PQXPUXSP mteoPIEdesktop kernelX IHTIRFQRRHHH tPFHHX exeption imsk HxH et HxH irr HxH tion HxP frozen xov IR PQXPUXSP mteoPIEdesktop kernelX IHTIRFQRRHHH tPFHHX md HGHHXHHXHHXHHXPHGHHXHHXHHXHHXHHGH tg H d HxH dt H xov IR PQXPUXSP mteoPIEdesktop kernelX IHTIRFQRRHHH res RHGHHXHQXHHXHHXHHGHHXHHXHHXHHXHHGH imsk HxR @timeoutA xov IR PQXPUXSU mteoPIEdesktop kernelX IHTIWFQVVHHH tPX port is slow to respondD plese e ptient @ttus HxdHA xov IR PQXPVXHP mteoPIEdesktop kernelX IHTPRFQWPHHH tPX devie not redy @errnoaEITAD foring hrdreset xov IR PQXPVXHP mteoPIEdesktop kernelX IHTPRFQWPHHH tPX soft resetting port xov IR PQXPVXHP mteoPIEdesktop kernelX IHTPRFWPVHHH tPFHHX onfigured for hweGQQ xov IR PQXPVXHP mteoPIEdesktop kernelX IHTPRFWPVHHH tPX ir omplete
Le problme de syslog c'est qu'il n'volue pas forcment toutes les secondes. Mais si vous tes patients et que vous regardez votre console, vous devriez le voir crire de nouvelles lignes sous vos yeux au bout d'un moment. Faites Ctrl + C (Ctrl et C en mme temps) pour arrter la commande tail.
connatre : la combinaison de touches Ctrl + C est utilisable dans la plupart des programmes console pour demander leur arrt. C'est un peu l'quivalent du Alt + F4 de Windows.
Pour tout vous dire, tail -f est une de mes commandes prfres sous Linux. C'est un bon moyen de surveiller ce qui se passe en temps rel sur un ordinateur (si vous tes assez rapides pour suivre). Par exemple, les logs Apache du Site du Zro permettent de voir en temps rel qui se connecte sur le site, avec quelle IP, quel chier a t charg, quelle heure, etc. Aux heures d'auence du site, ce chier volue tellement vite qu'il est pratiquement impossible de le suivre pour un humain. Je vous ai fait une petite vido d'un tail -f en action pour que vous vous rendiez compte de la chose. Elle est accessible grce au code web suivant (380 Ko) : Vido de tail -f en action Code web : 732196 Notez que par dfaut, tail -f recherche les nouveaux changements dans le chier toutes les secondes. Si vous voulez, vous pouvez rajouter le paramtre -s suivi d'un nombre. Par exemple, tail -f -s 3 syslog recherchera les changements toutes les trois secondes (plutt que toutes les secondes). Les nombres dcimaux sont accepts, 164
TOUCH
&
MKDIR
touch
Assez lu de chiers, maintenant voyons voir comment on les cre ! Nous allons d'abord voir comment crer un chier, puis comment crer un dossier, car ce n'est pas la mme commande. . .
touch
: crer un chier
En fait, il n'existe aucune commande spcialement faite pour crer un chier vide sous Linux (ce n'est pas trs utile). En gnral, on se contente d'ouvrir un diteur de texte et d'enregistrer, ce qui provoque la cration d'un chier comme sous Windows. La commande touch est la base faite pour modier la date de dernire modication d'un chier. D'o son nom : on touche le chier pour faire croire l'ordinateur qu'on vient de le modier alors que l'on n'a rien chang. a peut se rvler utile dans certains cas prcis qu'on ne verra pas ici. L'intrt de touch pour nous dans ce chapitre, c'est que si le chier n'existe pas, il sera cr ! On peut donc aussi utiliser touch pour crer des chiers, mme s'il n'a pas vraiment t fait pour a la base. La commande attend un paramtre : le nom du chier crer. Commencez par vous rendre dans votre dossier personnel ; ce n'est pas une bonne ide de mettre le bazar dans /var/log, le dossier personnel est l pour a. Si vous vous souvenez bien, il sut de taper cd :
mteoPIdmteoPIEdesktopXGvrGlog6 d mteoPIdmteoPIEdesktopX~6
165
CHAPITRE 11.
La commande ls -F que j'ai tape ensuite le montre, un chier appel fichierbidon (sans extension) a t cr. Bien entendu, vous pouvez crer un chier de l'extension que vous voulez :
mteoPIdmteoPIEdesktopX~6 touh utrefihieridonFtxt mteoPIdmteoPIEdesktopX~6 ls Ep utrefihieridonFtxt ixmplesd smgesG wusiqueG idosG hesktopG fihieridon logG uliG houmentsG imgesG wodlesG tutosG
Autre information intressante : vous pouvez crer plusieurs chiers en une seule commande. Il vous sut de les lister l'un aprs l'autre, spars par des espaces. Ainsi, on aurait pu crer nos deux chiers comme ceci :
touh fihieridon utrefihieridonFtxt
mkdir
: crer un dossier
La commande mkdir, elle, est faite pour crer un dossier. Elle fonctionne de la mme manire que touch.
mkdir mondossier
On peut crer deux dossiers (ou plus !) en mme temps en les sparant l aussi par des espaces :
mkdir mondossier utredossier
Si vous faites un ls, vous verrez que les dossiers ont bien t crs. :-) Il y a un paramtre utile avec mkdir : -p. Il sert crer tous les dossiers intermdiaires. Par exemple : 166
CP
&
MV
mkdir Ep nimuxGverteresGht
. . . crera le dossier animaux, puis l'intrieur le sous-dossier vertebres, puis l'intrieur encore le sous-dossier chat !
cp
Parmi les oprations de base que l'on veut pouvoir faire avec les chiers, il y a la copie et le dplacement de chier. C'est un peu le genre de chose que l'on fait tous les jours, il est donc important de savoir s'en servir.
cp
: copier un chier
La commande cp (abrviation de CoPy, copier en anglais) vous permet comme son nom l'indique de copier un chier. . . mais aussi de copier plusieurs chiers la fois, et mme de copier des dossiers ! Si on essayait de copier le chier fichierbidon qu'on a cr tout l'heure ? a fonctionne comme ceci :
p fihieridon fihieropie
Le premier paramtre est le nom du chier copier, le second le nom de la copie du chier crer. En faisant cela, on aura donc deux chiers identiques dans le mme rpertoire : fichierbidon et fichiercopie.
N'oubliez pas d'utiliser l'autocompltion avec la touche Tab ! Lorsque vous avez crit cp fic, tapez Tab, et fichierbidon devrait se complter tout seul !
Copier dans un autre dossier
On n'est pas oblig de copier le chier dans le mme dossier, bien sr. On peut trs bien utiliser le systme de rpertoires relatifs et absolus qu'on a vu dans le chapitre prcdent. Par exemple, si je veux copier fichierbidon dans le sous-dossier mondossier que j'ai cr tout l'heure :
p fihieridon mondossierG
Le chier fichierbidon sera copi dans mondossier sous le mme nom. 167
CHAPITRE 11.
Notez que mettre le / la n n'est pas obligatoire. Si vous le voyez l, c'est parce que l'autocompltion me l'a automatiquement ajout lorsque j'ai appuy sur Tab. Ehhh oui, je suis tellement emmard que je n'cris mme pas mondossier en entier, j'cris juste mon suivi de Tab, et hop c'est crit en entier ! a va beaucoup plus vite lorsqu'on prend ce rexe.
Si vous voulez copier fichierbidon dans mondossier sous un autre nom, faites comme ceci :
p fihieridon mondossierGfihieropie
Avec cette commande, on aura cr une copie de fichierbidon dans mondossier sous le nom fichiercopie ! Enn l, j'utilise des rpertoires relatifs, mais je peux aussi crire un rpertoire en absolu :
p fihieridon GvrGlogG
. . . cela aura pour eet de copier animaux ainsi que tous ses sous-dossiers sous le nom autresanimaux. Faites des ls aprs pour vrier que les sous-dossiers sont bien l et que je ne vous mne pas en bateau !
Utiliser le joker *
Le symbole * est appel joker, ou encore wildcard en anglais sous Linux. Il vous permet de copier par exemple tous les chiers image .jpg dans un sous-dossier :
p BFjpg mondossierG
Vous pouvez aussi vous en servir pour copier tous les chiers dont le nom commence par so : 168
CP
&
MV
p soB mondossierG
Le joker est un atout trs puissant, n'hsitez pas l'utiliser ! C'est avec des outils comme le joker que la console deviendra pour vous progressivement plus puissante que l'explorateur de chiers que vous manipulez la souris.
mv
: dplacer un chier
Trs proche de cp, la commande mv (MoVe, dplacer en anglais) a en fait deux utilits : dplacer un chier (ou un dossier) ; renommer un chier (ou un dossier). Vous allez comprendre pourquoi.
Dplacer un chier
La commande mv s'utilise pratiquement comme cp :
mv fihieridon mondossierG
Au lieu de copier fichierbidon dans mondossier comme on l'a fait tout l'heure, ici on a juste dplac le chier. Il n'existe plus dans son dossier d'origine. Vous pouvez dplacer des dossiers aussi simplement :
mv nimuxG mondossierG
. . . dplacera le dossier animaux (et tous ses sous-dossiers) dans mondossier. Vous pouvez aussi utiliser les jokers :
mv BFjpg mondossierG
Renommer un chier
La commande mv permet de faire quelque chose d'assez tonnant : renommer un chier. En eet, il n'existe pas de commande spciale pour renommer un chier en console sous Linux, c'est la commande mv qui est utilise pour a. Par exemple : 169
CHAPITRE 11.
mv fihieridon superfihier
. . . renommera fichierbidon en superfichier. Aprs cette commande, fichierbidon n'existe plus, il a t renomm.
Et voil le travail ! Je vous conseille fortement de vous entraner utiliser cp et mv dans tous les sens : avec ou sans joker, en dplaant, renommant des dossiers, en dplaant / renommant la fois, en utilisant des chemins relatifs et absolus, etc. C'est assez intuitif normalement, mais il faut pratiquer et pas seulement se contenter de lire ce que j'cris pour que a rentre.
N'oubliez pas d'utiliser l'autocompltion de chiers et dossiers avec la touche Tab ; si vous ne le faites pas ds maintenant, vous perdrez du temps et vous trouverez la console nulle alors que vous devriez la trouver gniale. Autre chose : le symbole .. signie dossier prcdent , et . signie dossier dans lequel je me trouve . Vous pourriez en avoir besoin lorsque vous copiez ou dplacez un chier.
Si vous avez la tte qui tourne force de copier et dplacer des chiers dans des dossiers, c'est normal. a commence devenir un beau bazar dans vos dossiers d'ailleurs, non ? Il est temps de faire un peu de mnage avec la commande permettant de supprimer : rm !
rm
On attaque la commande qui fche : rm. Pourquoi est-ce qu'elle fche ? Parce qu'il n'existe pas de corbeille dans la console de Linux : le chier est directement supprim sans possibilit de rcupration !
rm
: supprimer un chier
La commande rm (pour ReMove, supprimer en anglais) peut supprimer un chier, plusieurs chiers, des dossiers, voire mme votre ordinateur entier si vous le voulez. 170
RM
Il faut donc l'utiliser avec prcaution. Commenons par des choses simples, supprimons ce fichierbidon :
rm fihieridon
Normalement, on ne vous demande pas de conrmation, on ne vous ache rien. Le chier est supprim sans autre forme d'avertissement. Brutal, hein ? Vous pouvez aussi supprimer plusieurs chiers en sparant leurs noms par des espaces :
rm fihieridon fihieropie
-i
: demander conrmation
La commande -i permet de vous demander une conrmation pour chacun des chiers :
mteoPIdmteoPIEdesktopX~6 rm Ei fihieridon rmX dtruire fihier rgulier vide fihieridon9c
Lorsqu'on vous demande une conrmation de type oui/non comme ici, vous devez rpondre par une lettre : o : signie Oui . Sur certains systmes anglais, il faudra peut-tre utiliser y de Yes ; n : signie Non . Tapez ensuite sur Entre pour valider.
-f
-f, c'est un peu le contraire de -i : c'est le mode des gros bourrins. Ce paramtre force
la suppression, ne demande pas de conrmation, mme s'il y a un problme potentiel. En raison des risques que cela comporte, utilisez-le aussi rarement que possible.
rm Ef fihieridon
-v
Le paramtre -v (Verbose, verbeux en anglais, c'est--dire parler beaucoup ) est un paramtre que l'on retrouve dans beaucoup de commandes sous Linux. Il permet de demander la commande de dire ce qu'elle est en train de faire. Comme vous l'avez vu, par dfaut la commande rm est silencieuse. Si vous supprimez de trs nombreux chiers, a peut prendre du temps. Pour viter que vous vous impatientiez, pensez utiliser -v : 171
CHAPITRE 11.
Vous voyez au fur et mesure de l'avancement ce qui est en train d'tre fait. Trs pratique !
-r
Le paramtre -r peut tre utilis pour supprimer un dossier (au lieu d'un chier) ainsi que tout ce qu'il contient : chiers et dossiers ! C'est un paramtre assez dangereux, faites donc bien attention de l'utiliser sur un dossier dont vous ne voulez vraiment plus, car tout va disparatre l'intrieur :
rm Er nimuxG
. . . supprime le dossier animaux ainsi que tout ce qu'il contenait (sous-dossiers vertebres et chat).
Notez qu'il existe aussi la commande rmdir. La grosse dirence avec rm -r, c'est que rmdir ne peut supprimer un dossier que s'il est vide ! Il faudra y avoir fait le mnage auparavant.
rm
Bon, vous tes grands, je crois que le moment est venu de vous rvler un terrible secret : les enfants ne naissent pas dans les choux. Euh pardon, je voulais dire : la commande rm est vraiment dangereuse. Trs dangereuse. Vous pouvez potentiellement bousiller tout votre systme avec !
Je vais vous montrer quelque chose d'horrible, d'areux, d'interdit aux moins de 18 ans, bref vous m'avez compris, le truc ne faire sous aucun prtexte, mme pas en cauchemar.
xyx xyx xyx xi pesi tewes ge 333 ab rm Erf GB
Je me suis permis de mettre du texte avant pour vous viter la tentation de recopier btement la commande pour rigoler , pour voir ce que a fait . Je vais vous l'expliquer dans le dtail, parce que c'est quand mme l'erreur no 1 ne pas faire sous Linux. 172
LN
rm : commande la suppression ; -r : supprime de manire rcursive tous les chiers et dossiers ; -f : force la suppression sans demander la moindre conrmation ; /* : supprime tous les chiers et dossiers qui se trouvent la racine (/) quel que soit leur nom (joker *).
En clair, cette commande supprime tout votre disque dur depuis la racine, sous-dossiers compris, et ne demande aucune conrmation. Aucune possibilit de rcupration, votre PC est foutu. Vous tes bons pour une rinstallation de Linux, et aussi de Windows si la partition de Windows tait accessible depuis Linux.
Mais ils sont btes les gens qui ont cr cette commande ! Pourquoi autoriser de faire une chose aussi risque ?
En fait, il y a plusieurs mcanismes de protection. On en apprendra plus dans le prochain chapitre (qui traitera des utilisateurs et de leurs droits). Par exemple, les chiers la racine ne vous appartiennent pas, ils appartiennent au superutilisateur root . Moi je me suis logg en tant que mateo21, je n'ai donc thoriquement pas le droit de supprimer ces chiers. La suppression sera refuse. Seulement, pour peu que vous soyez loggs en tant que root (on verra comment le faire dans le chapitre suivant), vous aurez le droit de le faire, et l plus rien ne vous arrtera ! On apprendra plus tard comment utiliser les alias de commande pour viter qu'une commande aussi dangereuse ne s'excute. En attendant, ne jouez pas avec le feu, car vous y perdriez les mains, les pieds, la tte et tout ce qui va avec. Le joker reste quand mme trs utile, mais lorsque vous l'utilisez avec rm, triplez d'attention. Par exemple :
rm Erf B
. . . supprime tous les chiers et sous-dossiers du dossier dans lequel je me trouve. Il m'arrive de l'utiliser, d'en avoir besoin, mais chaque fois je fais trs trs attention ce qu'il n'y ait plus rien dans ce dossier (et dans les sous-dossiers) qui m'intresse. Comme vous pouvez le voir, il n'y a qu'un seul caractre de dirence (le /) avec la commande de la mort que je vous ai montre un peu plus haut. Une erreur est vite arrive. J'ignore combien de gens se sont pendus aprs avoir excut cette commande, mais a mritait au moins un GROS avertissement !
ln
Bien qu'un peu moins courante, la commande ln vous sera certainement utile un jour ou l'autre. Elle permet de crer des liens entre des chiers, c'est--dire (pour employer des mots que vous connaissez) qu'elle permet de crer des raccourcis. 173
CHAPITRE 11.
Ces raccourcis , qu'on appelle des liens sous Linux, sont un peu plus complexes que ceux que vous avez l'habitude de voir sous Windows. En eet, on peut crer deux types de liens : des liens physiques ; des liens symboliques. Ces deux types ne fonctionnent pas de la mme manire. Pour comprendre ce qui les direncie, il faut savoir comment un OS tel que Linux gre les chiers sur le disque dur. Allons, allons, ne faites pas cette tte-l, un peu de thorie sur le fonctionnement des OS, c'est toujours trs intressant ! :-)
Je simplie ici volontairement les choses. En pratique, c'est (toujours) un peu plus compliqu. Il y en fait trois parties : le nom, les informations de gestion (droits d'accs) et le contenu. Mais nous allons faire simple car notre but est juste de comprendre l'ide gnrale du fonctionnement.
Chaque contenu de chier se voit attribuer un numro d'identication appel inode (gure 11.1). Chaque nom de chier est donc associ un inode (son contenu).
LN
On ne peut pas crer de liens physiques sur des rpertoires. Cela ne fonctionne qu'avec les chiers. Il existe des options pour que a fonctionne avec des rpertoires, mais c'est un peu particulier et on n'en parlera pas. Pour faire un raccourci vers un rpertoire, on prfrera utiliser un lien symbolique.
Pour crer un lien physique, nous allons utiliser la commande ln. Je vous propose tout d'abord de crer un rpertoire pour nos tests :
mkdir tests d tests
Une fois dans ce dossier, crez un chier avec la commande touch par exemple :
touh fihierI
Nous voulons maintenant crer un lien physique : nous allons crer un fichier2 qui partagera le mme inode (le mme contenu) que fichier1. Tapez :
ln fihierI fihierP
Si vous listez les chiers du rpertoire, vous avez l'impression d'avoir deux chiers dirents : 175
CHAPITRE 11.
mteoPIdmteoPIEdesktopX~Gtests6 ls El totl H ErwErEErEE P mteoPI mteoPI H PHHVEHUEQI IQXSS fihierI ErwErEErEE P mteoPI mteoPI H PHHVEHUEQI IQXSS fihierP
A priori, rien ne nous permet ici de deviner que ces chiers modient le mme contenu. Le lien physique est donc un lien dur, pas vident dtecter au premier coup d'il.
La seconde colonne de la liste (qui indique 2 pour chacun des chiers) correspond au nombre de chiers qui partagent le mme inode. C'est le seul indice qui vous permet de savoir que quelqu'un a fait un lien physique, mais vous ne pouvez pas savoir lequel. Le seul moyen de vrier que ces chiers partagent le mme contenu, c'est de faire ls -i pour acher les numros d'inode correspondants et de vrier que ces deux chiers sont associs au mme inode. En temps normal, sur la plupart des chiers la seconde colonne indique donc 1 . Si c'est un dossier, ce nombre indique en revanche le nombre de chiers l'intrieur.
Si vous supprimez un des deux chiers, l'autre chier reste en place et le contenu sera toujours prsent sur le disque. L'inode est supprim uniquement quand plus aucun nom de chier ne pointe dessus. En clair, supprimez fichier1 pour voir. Vous verrez que fichier2 existe toujours et qu'il ache toujours le mme contenu. Il faut supprimer fichier1 ET fichier2 pour supprimer le contenu.
LN
Supprimez le fichier2 que nous avons cr tout l'heure (sous forme de lien physique) :
rm fihierP
Crons maintenant un nouveau fichier2, cette fois sous forme de lien symbolique. On utilise l encore la commande ln, mais avec le paramtre -s (s comme symbolique) :
ln Es fihierI fihierP
On note deux choses : la toute premire lettre de la seconde ligne est un l (comme link, c'est--dire lien) ; tout la n de la seconde ligne, une che montre clairement que fichier2 pointe vers fichier1. Bref, les liens symboliques sont beaucoup plus faciles reprer que les liens physiques !
Ok, mais quelles dirences part a ? Le rsultat revient au mme, non ? Qu'on ouvre fichier1 ou fichier2, on ditera le mme contenu au nal !
Tout fait. Il y a quand mme quelques subtilits : par exemple, si vous supprimez fichier2, il ne se passe rien de mal. Par contre, si vous supprimez fichier1, fichier2 pointera vers un chier qui n'existe plus. Le lien symbolique sera cass et ne servira donc plus rien. On parle de lien mort ; d'autre part, l'avantage des liens symboliques est qu'ils fonctionnent aussi sur des rpertoires, contrairement aux liens physiques.
En rsum
cat permet d'acher tout le contenu d'un chier, mais lorsque celui-ci est long, il est prfrable d'utiliser less qui ache le chier page par page. On peut obtenir uniquement le dbut ou la n d'un chier avec head et tail. En utilisant tail -f on peut suivre l'volution d'un chier en temps rel, ce qui est utile sur les chiers de log qui enregistrent l'activit du systme. 177
CHAPITRE 11.
mkdir permet de crer un dossier, touch permet de crer un chier vide. cp permet de copier un chier ou un dossier, tandis que mv permet de les dplacer ou de les renommer. rm supprime un chier. Il n'y a pas de corbeille en console, la suppression est dnitive ; il faut donc tre prudent. On peut crer des liens (raccourcis) vers des chiers et dossiers l'aide de la commande ln.
178
Chapitre
12
Dicult :
inux est un systme multi-utilisateur. Cela signie que plusieurs personnes peuvent travailler simultanment sur le mme OS, en s'y connectant distance notamment. Puisque plusieurs utilisateurs peuvent tre connects Linux en mme temps, celui-ci doit avoir une excellente organisation ds le dpart. Ainsi chaque personne a son propre compte utilisateur, et il existe un ensemble de rgles qui disent qui a le droit de faire quoi. Je vous propose de dcouvrir tous ces mcanismes dans ce chapitre.
179
CHAPITRE 12.
sudo
Lorsque vous avez install Ubuntu, on vous a demand le nom du compte utilisateur que vous vouliez crer. Par exemple dans mon cas j'ai cr l'utilisateur mateo21 . Dans la plupart des distributions Linux on vous proposera de crer un compte utilisateur avec des droits limits, comme c'est le cas pour mon compte mateo21 .
Attends, c'est nous qui avons install Linux mais on n'a pas le droit de faire tout ce que l'on veut dessus ?
Oui, et c'est une scurit. Bien sr, comme vous tes aux commandes, vous pouvez tout moment dire : Bon allez on passe en mode chef-qui-peut-tout-faire . Mais c'est une scurit de ne pas avoir le droit de tout faire par dfaut, car certaines commandes peuvent tre dangereuses pour la stabilit et la scurit de votre ordinateur. Avoir des droits limits, cela signie aussi qu'on s'empche par exemple d'excuter la commande de la mort qui tue qu'on a vue dans le chapitre prcdent (rm -rf /*). Nous allons d'abord commencer par voir comment sont organiss les utilisateurs sous Linux, puis nous verrons comment devenir le chef . Plus loin dans le chapitre, nous apprendrons crer et supprimer des utilisateurs en ligne de commande.
SUDO
Par dfaut, vous tes connects sous votre compte limit (mateo21 pour ma part). Il est impossible sous Ubuntu de se connecter directement en root au dmarrage de l'ordinateur. Comment faire alors pour excuter des commandes que seul root a le droit d'excuter ? On peut devenir root temporairement l'aide de la commande sudo. Cette commande signie Faire en se substituant l'utilisateur : Substitute User DO. crivez donc sudo suivi de la commande que vous voulez excuter, comme ceci :
sudo ommnde
On vous demandera normalement votre mot de passe (au moins la premire fois) pour excuter la commande. Ce mot de passe est le mme que celui de votre compte utilisateur limit. 181
CHAPITRE 12.
Par exemple, vous pouvez excuter un simple ls avec les droits root (vous ne risquez rien, rassurez-vous) :
mteoPIdmteoPIEdesktopXGhome6 sudo ls sudo pssword for mteoPIX utredossier hesktop ixmples smges utresnimux houments imges log
wodles mondossier
Comme vous le voyez, on vous demande d'abord le mot de passe, par scurit. Faire un ls en tant que root n'apporte rien de bien spcial, c'tait simplement pour avoir un exemple sr avec lequel vous ne risquez pas d'endommager votre ordinateur.
sudo su
Le symbole # la n de l'invite de commandes vous indique que vous tes devenus superutilisateur. Vous pouvez alors excuter autant de commandes en root que vous le voulez. Pour quitter le mode root , tapez exit (ou faites la combinaison Ctrl + D).
rootdmteoPIEdesktopXGhomeGmteoPI5 exit exit mteoPIdmteoPIEdesktopX~6
Sous les autres distributions qu'Ubuntu, crire su sut passer root. Il est nanmoins recommand dans ce cas d'ajouter un tiret en paramtre, c'est-dire d'crire su - . L'ajout du tiret a pour eet de rendre accessibles certains programmes destins seulement root. Par ailleurs, cela vous place directement dans le dossier personnel de root (/root).
adduser, deluser
Maintenant que vous savez passer root (temporairement ou indniment), nous allons pouvoir dcouvrir des commandes qui sont rserves root. adduser et deluser sont 182
ADDUSER, DELUSER
de celles-l. Si vous essayez de les appeler avec votre utilisateur normal, on vous dira que vous n'avez pas le droit de les utiliser. Seul root peut grer les utilisateurs.
adduser
: ajouter un utilisateur
La commande adduser permet d'ajouter un utilisateur. Vous devez au minimum fournir un paramtre : le nom de l'utilisateur crer. Par exemple, pour crer un compte pour Patrick :
rootdmteoPIEdesktopXGhome5 dduser ptrik ejout de l9utilisteur ptrik FFF ejout du nouveu groupe ptrik @IHHIAFFF ejout du nouvel utilisteur ptrik @IHHIA ve le groupe ptrik grtion du rpertoire personnel GhomeGptrik FFF gopie des fihiers depuis GetGskel FFF
FFF
Pensez rajouter un sudo devant la commande si vous n'tes pas dj root ; pour cela, tapez sudo adduser patrick. Moi je n'ai pas eu le faire car j'ai choisi de rester root indniment en tapant sudo su auparavant. Si vous tentez d'excuter la commande avec votre compte limit, vous aurez une erreur de ce genre : adduser : Seul le superutilisateur peut ajouter un utilisateur ou un groupe sur le systme . Le rpertoire personnel de patrick est automatiquement cr (/home/patrick) et son compte est prcongur. On vous demande ensuite de taper son mot de passe :
intrez le nouveu mot de psse xs X etpez le nouveu mot de psse xs X psswd X le mot de psse t mis jour ve sus
Tapez le mot de passe de patrick puis faites Entre. Retapez-le pour valider. Encore une fois, si vous ne voyez pas d'toiles * quand vous tapez le mot de passe, c'est normal ; c'est une scurit pour qu'on ne puisse pas compter le nombre de caractres derrire votre paule. On vous propose ensuite de rentrer quelques informations personnelles sur patrick, comme son nom, son numro de tlphone. . . Si vous voulez le faire, faites-le, mais sinon sachez que vous pouvez taper Entre sans rien crire ; on ne vous embtera pas.
wodifition des informtions reltives l9utilisteur ptrik intrez l nouvelle vleur ou intre pour onserver l vleur propose xom omplet X x de ureu X lphone professionnel X lphone personnel X eutre X ges informtions sontEelles orretes c oGx o
183
CHAPITRE 12.
la n, on vous demande de conrmer par un o (oui) que tout est bon. Tapez Entre et a y est, le compte de patrick est cr !
passwd
S'il tait ncessaire de changer le mot de passe de patrick par la suite, utilisez la commande passwd en indiquant en paramtre le nom du compte modier.
rootdmteoPIEdesktopXGhome5 psswd ptrik intrez le nouveu mot de psse xs X etpez le nouveu mot de psse xs X psswd X le mot de psse t mis jour ve sus
Attention ! Si vous appelez passwd sans prciser de compte en paramtre, c'est le mot de passe de root que vous changerez !
deluser
: supprimer un compte
patrick vous ennuie ? patrick est parti ? Si son compte n'est plus ncessaire (ou que vous voulez vous venger) vous pouvez le supprimer avec deluser.
deluser ptrik
Ne supprimez en aucun cas votre compte utilisateur ! Par exemple, je ne dois surtout pas supprimer le compte mateo21. En eet, si je le fais, il n'y aura plus que root sur la machine. . . et Ubuntu interdit de se logger en root. Par consquent, au prochain dmarrage de la machine vous ne pourrez pas vous connecter. . . et vous serez compltement coincs !
Toutefois, cette commande seule ne supprime pas le rpertoire personnel de patrick. Si vous voulez supprimer aussi son home et tous ses chiers personnels, utilisez le paramtre --remove-home :
deluser EEremoveEhome ptrik
184
et deluser sont des commandes qui n'existent que sous Debian et tous ses descendants, dont Ubuntu. Partout ailleurs on doit utiliser useradd et userdel, qui sont les commandes Unix traditionnelles fonctionnant partout. Elles font globalement la mme chose mais de manire beaucoup plus basique : si vous n'appelez pas passwd vous-mmes, le compte ne sera pas activ et n'aura pas de mot de passe.
addgroup, delgroup
Oui mais dans ce cas, quel groupe appartiennent les utilisateurs mateo21 et patrick ? On n'a rien dni, nous !
En eet, si vous ne dnissez rien, un groupe du mme nom que l'utilisateur sera automatiquement cr : ainsi, mateo21 appartient au groupe mateo21 et patrick au groupe patrick. On peut le vrier en regardant qui appartiennent les dossiers dans /home via un ls -l :
rootdmteoPIEdesktopX~5 d Ghome rootdmteoPIEdesktopXGhome5 ls El totl PR drwxEEEEEE P root root ITQVR PHHUEHWEIW IVXPP lostCfound drwxrExrEx TS mteoPI mteoPI RHWT PHHUEIIEIS PPXRH mteoPI drwxrExrEx P ptrik ptrik RHWT PHHUEIIEIS PQXHH ptrik
Souvenez-vous : la 3e colonne indique le propritaire du chier ou dossier ; la 4e indique le groupe qui possde ce chier ou dossier. Ainsi, le dossier mateo21 appartient l'utilisateur mateo21 et au groupe mateo21. Mme chose pour patrick. On constatera par ailleurs que lost+found appartient root et qu'il y a un groupe root (root fait donc partie du groupe root). Bon, mais quel intrt y a-t-il ce que tout le monde soit dans son propre groupe, me direz-vous ? Vous pourriez trs bien vous contenter de ce fonctionnement (un utilisateur = un groupe), mais au cas o vous auriez beaucoup d'utilisateurs, je vais quand mme vous montrer comment crer des groupes.
addgroup
: crer un groupe
La commande addgroup cre un nouveau groupe. Vous avez juste besoin de spcier le nom de celui-ci en paramtre : 185
CHAPITRE 12.
usermod
: modier un utilisateur
La commande usermod permet d'diter un utilisateur. Elle possde plusieurs paramtres ; nous allons en retenir deux : -l : renomme l'utilisateur (le nom de son rpertoire personnel ne sera pas chang par contre) ; -g : change de groupe. Si je veux mettre patrick dans le groupe amis, je ferai donc comme ceci :
usermod Eg mis ptrik
Il est aussi possible de faire en sorte qu'un utilisateur appartienne plusieurs groupes. Pour ce faire, utilisez le paramtre -G (majuscule). Exemple : usermod -G amis,paris,collegues patrick. Sparez les noms des groupes par une virgule, sans espace entre chaque nom de groupe. Faites trs attention en utilisant usermod ! Lorsque vous avez recours -G, l'utilisateur change de groupe et ce peu importe les groupes auxquels il appartenait auparavant. Si vous voulez ajouter des groupes un utilisateur (sans perdre les groupes auxquels il appartenait avant cela), utilisez -a :
usermod -aG amis patrick
delgroup
: supprimer un groupe
186
CHOWN, CHGRP
addgroup et delgroup n'existent que sous Debian et ses drivs (mme remarque que pour adduser et deluser). Les commandes traditionnelles qui fonctionnent partout sont groupadd et groupdel, mais elles orent moins d'options.
chown, chgrp
Seul l'utilisateur root peut changer le propritaire d'un chier. Supposons par exemple que mateo21 possde dans son rpertoire personnel un chier appel rapport.txt. Voici le rsultat d'un ls -l pour ce chier :
mteoPIdmteoPIEdesktopX~6 ls El rpportFtxt ErwErEErEE I mteoPI mteoPI H PHHUEIIEIS PQXIR rpportFtxt
Petite astuce : comme vous venez de le voir, si on prcise un nom de chier en dernier paramtre de la commande ls, on ne verra que ce chier dans les rsultats. Le joker * est l aussi utilisable : ls -l *.jpg acherait uniquement les images JPEG contenues dans ce dossier.
Ce chier, je souhaite le donner patrick. C'est l qu'intervient la commande chown.
chown
La commande chown, qui doit tre utilise en tant que root, attend deux paramtres au moins : le nom du nouveau propritaire ; le nom du chier modier. Cela donne donc :
hown ptrik rpportFtxt
On peut voir ensuite que patrick est bien le nouveau propritaire du chier :
rootdmteoPIEdesktopXGhomeGmteoPI5 ls El rpportFtxt ErwErEErEE I ptrik mteoPI H PHHUEIIEIS PQXIR rpportFtxt
CHAPITRE 12.
chgrp
chgrp s'utilise exactement de la mme manire que chown la dirence prs qu'il
Cette commande aectera le chier rapport.txt au groupe amis. Un petit ls -l nous conrmera que rapport.txt appartient dsormais patrick et au groupe amis :
rootdmteoPIEdesktopXGhomeGmteoPI5 ls El rpportFtxt ErwErEErEE I ptrik mis H PHHUEIIEIS PQXIR rpportFtxt
chown
Cela aectera le chier l'utilisateur patrick et au groupe amis. Il sut de sparer par un symbole deux points ( : ) le nom du nouvel utilisateur ( gauche) et le nom du nouveau groupe ( droite).
-R
Trs utile aussi, l'option -R de chown. Elle modie tous les sous-dossiers et chiers contenus dans un dossier pour y aecter un nouvel utilisateur (et un nouveau groupe si on utilise la technique du deux points que l'on vient de voir). Par exemple, si je suis sadique et que je veux donner tout le contenu du dossier personnel de patrick mateo21 (et au groupe mateo21), c'est trs simple :
hown E mteoPIXmteoPI GhomeGptrikG
Rsultat :
rootdmteoPIEdesktopXGhome5 ls El totl PR drwxEEEEEE P root root ITQVR PHHUEHWEIW IVXPP lostCfound drwxrExrEx TP mteoPI mteoPI RHWT PHHUEIIEIS PQXIW mteoPI drwxrExrEx P mteoPI mteoPI RHWT PHHUEIIEIS PQXHH ptrik
188
CHMOD
chmod
On attaque maintenant la partie la plus coton du chapitre si je puis dire : les droits d'accs.
PHHUEIIEIQ PIXSQ hesktop PHHUEIIEIQ IQXRT houments PHHUEHWEIW IVXQI ixmples PHHUEHWEPS PHHUEIHEIW PHHUEHWEPS PHHUEIHEIW PHHUEIHEIW PHHUEIHEIW PHHUEIIEIS PHHUEHWEIW PHHUEIHEIW PHXPV HIXPI IIXII HIXPI HIXPI HIXPI PQXIR IWXSI HIXPI imges smges log wodles wusique uli rpportFtxt tutos idos
Vous voyez tous ces d, r, w et x au dbut ? Ce sont ce qu'on appelle les droits d'accs du chier ou dossier. On peut voir cinq lettres direntes. Voici leur signication : d (Directory) : indique si l'lment est un dossier ; l (Link) : indique si l'lment est un lien (raccourci) ; r (Read) : indique si on peut lire l'lment ; w (Write) : indique si on peut modier l'lment ; x (eXecute) : si c'est un chier, x indique qu'on peut l'excuter. Ce n'est utile que pour les chiers excutables (programmes et scripts). Si c'est un dossier, x indique qu'on peut le traverser , c'est--dire qu'on peut voir les sous-dossiers qu'il contient si on a le droit de lecture dessus.
1. Je sais, je suis vraiment trop diabolique.
189
CHAPITRE 12.
Si la lettre apparat, c'est que le droit existe. S'il y a un tiret la place, c'est qu'il n'y a aucun droit.
Ses droits sont : -rw-r--r- - : le premier tiret indique qu'il ne s'agit pas d'un dossier. S'il y avait eu un d la place, cela aurait indiqu qu'il s'agissait d'un dossier. rw- : indique que le propritaire du chier, mateo21 en l'occurrence, peut lire et modier (et donc supprimer) le chier. En revanche, il ne peut pas l'excuter car il n'a pas de x la n. Je rappelle que quiconque peut modier un chier a aussi le droit de le supprimer. r-- : tous les utilisateurs qui font partie du groupe mateo21 mais qui ne sont pas mateo21 peuvent seulement lire le chier. Ils ne peuvent ni le modier, ni l'excuter. Je reconnais qu'avoir un nom de groupe identique au nom d'utilisateur peut embrouiller : si vous tes aussi bien organiss que sur mon premier schma, on parlera plutt du groupe famille. r-- : tous les autres (ceux qui ne font pas partie du groupe mateo21) peuvent seulement lire le chier. En rsum, ces droits nous apprennent que l'lment est un chier, que mateo21 peut le lire et le modier et que tous les autres utilisateurs peuvent seulement le lire. 190
CHMOD
chmod
Maintenant que nous savons voir et comprendre les droits d'accs d'un chier, nous allons apprendre les modier l'aide de la commande chmod. Une prcision importante pour commencer : contrairement aux commandes prcdentes, vous n'avez pas besoin d'tre root pour utiliser chmod. Vous devez juste tre propritaires du chier dont vous voulez modier les droits d'accs. chmod est un petit peu dlicat utiliser. En eet, on peut attribuer les droits sur un chier / dossier via plusieurs mthodes direntes, la plus courante tant celle des chires.
Droit Chire
r w x 4 2 1
Si vous voulez combiner ces droits, il va falloir additionner les chires correspondants. Ainsi, pour attribuer le droit de lecture et de modication, il faut additionner 4 + 2, ce qui donne 6. Le chire 6 signie donc Droit de lecture et d'criture . Voici la liste des droits possibles et la valeur correspondante :
C'est compris ? Avec a, on peut calculer la valeur d'un triplet de droits. Il faut faire le 191
CHAPITRE 12.
mme calcul pour les droits que l'on veut attribuer au propritaire, au groupe et aux autres. Par exemple, 640 indique les droits du propritaire, du groupe et des autres (dans l'ordre). 6 : droit de lecture et d'criture pour le propritaire. 4 : droit de lecture pour le groupe. 0 : aucun droit pour les autres. Le droit maximal que l'on puisse donner tout le monde est 777 : droit de lecture, d'criture et d'excution pour le propritaire, pour son groupe et pour tous les autres. Bref, avec un tel droit tout le monde peut tout faire sur ce chier. Au contraire, avec un droit de 000, personne ne peut rien faire. . . part root, bien sr. Pour changer les droits sur le chier rapport.txt, et tre le seul autoris le lire et l'diter, je dois excuter cette commande :
hmod THH rpportFtxt
Bingo ! On a bien conrmation que seul le propritaire du chier, c'est--dire moi, peut le lire et le modier !
CHMOD
Signication : Aecter tous les droits au propritaire, juste la lecture au groupe, rien aux autres . Voil, ouf ! J'ai prfr vous expliquer le fonctionnement travers des exemples concrets plutt que de faire un cours thorique sur la syntaxe d'une des utilisations possibles de chmod. Normalement si vous suivez mes exemples vous devriez tre capables de tout faire !
CHAPITRE 12.
En rsum
Chaque personne qui utilise une machine Linux possde un compte utilisateur. Les utilisateurs sont classs par groupes. Il existe un superutilisateur qui a tous les droits : root. C'est l'administrateur de la machine, le seul tre autoris installer des programmes ou eectuer certaines modications sur le systme. Certaines commandes ne fonctionnent que lorsqu'on est root et ncessitent donc de se transformer en root l'aide de sudo. C'est le cas de la commande d'ajout d'utilisateur (adduser), de suppression d'utilisateur (deluser) ou encore de changement de propritaire d'un chier (chown). On peut modier les droits d'accs un chier avec chmod. Il existe trois types de droits : r (droit de lecture), w (droit d'criture) et x (droit d'excution).
194
Chapitre
13
Dicult :
ous avons dcouvert plusieurs faons de voir le contenu d'un chier en console. Mais. . . aucune des commandes que nous avons tudies ne nous permettait d'diter un chier. Pourquoi ai-je repouss le moment o je vous parlerais des diteurs de texte ? Parce que c'est un des domaines les plus riches de la console ! Parmi les plus clbres diteurs de texte console de Linux, il faut connatre : Nano, Vim et Emacs. Que de jolis noms, n'est-ce pas ? Des trois que je viens de citer, Nano est de loin le plus simple utiliser. Ce n'est pas pour rien que ce chapitre s'intitule Nano, l'diteur de texte du dbutant . Nous dcouvrirons Vim plus loin dans ce livre, car il est plus complexe et ncessite dj un bon niveau.
195
CHAPITRE 13.
196
Dcouverte de Nano
Le nom complet de Nano est GNU nano , en rfrence au projet GNU dont je vous ai parl dans le tout premier chapitre. Il s'agit d'un logiciel qui s'inspire de pico , un diteur de texte plus ancien qui se voulait lui aussi trs simple d'utilisation. Pour dmarrer le logiciel, il vous sut simplement de taper nano dans la console :
nno
CHAPITRE 13.
La recherche
La combinaison de touches Ctrl + W lance une recherche dans le chier (gure 13.4). Il vous sut d'crire le mot que vous recherchez (gure 13.5). . . . . . puis de taper Entre (gure 13.6). Le curseur est automatiquement positionn la premire occurrence trouve. Si le curseur est la n, la recherche recommence du dbut. 198
199
CHAPITRE 13.
+ C
Si vous souhaitez aller au rsultat suivant (au deux suivant), faites nouveau Ctrl + W pour lancer une recherche. La recherche prcdente est sauvegarde et apparat entre crochets. Si vous voulez rechercher le mme mot (et donc aller au rsultat suivant), tapez juste Entre sans crire de mot rechercher (gure 13.7).
Enregistrer et quitter
Pour enregistrer tout moment, faites Ctrl + O. Si vous essayez de quitter (Ctrl + X) sans enregistrer auparavant, un message vous demandera si vous voulez sauvegarder (gure 13.8). Si vous appuyez sur la touche o, vous passerez en mode enregistrement. Si vous appuyez sur la touche n, Nano quittera sans enregistrer. Si vous utilisez la combinaison Ctrl + C, vous annulerez votre demande de sortie de Nano et ne quitterez donc pas le logiciel. En appuyant sur o, vous vous retrouvez en mode enregistrement. Tapez juste le nom du chier que vous voulez crer puis pressez Entre (gure 13.9). Aprs a, Nano sera ferm et vous retrouverez votre bonne vieille ligne de commandes. 200
201
CHAPITRE 13.
. . . ouvrira le chier salut.txt que l'on vient de crer. Si le chier n'existe pas, il sera automatiquement cr par Nano lors du premier enregistrement. part a, la commande nano accepte de nombreux paramtres. Pour vous, j'en ai slectionn trois qui me semblent faire partie des plus utiles. -m : autorise l'utilisation de la souris sous Nano. En console, oui, oui. Vous pouvez vous en servir pour cliquer avec votre souris sur la zone de texte o vous voulez placer votre curseur. -i : indentation automatique. L'alina (tabulations) de la ligne prcdente sera respect lorsque vous irez la ligne. Trs utile lorsque vous ditez un chier de code source. -A : active le retour intelligent au dbut de la ligne. Normalement, lorsque vous appuyez sur la touche Origine (aussi connue sous le nom de Home) situe ct de la touche Fin, le curseur se repositionne au tout dbut de la ligne. Avec cette commande, il se positionnera aprs les alinas. Comme -i, il s'agit d'une option utile avant tout pour les programmeurs. 202
.NANORC
Si je veux lancer Nano avec toutes ces options la fois, je peux donc crire :
nno Emie slutFtxt
Pourquoi .nanorc ?
La plupart des chiers de conguration commencent par un point. Cela permet de cacher le chier quand on fait un ls. Bien entendu, comme vous devriez maintenant le savoir, les chiers cachs peuvent toujours tre achs en utilisant le paramtre -a : ls -a. Chaque utilisateur de la machine peut crer son propre chier de conguration .nanorc dans son rpertoire personnel (home). Chez moi, ce chier doit tre plac la position : /home/mateo21/.nanorc. Ce chier est lu par Nano chaque fois que vous le dmarrez.
Je viens de regarder la liste des chiers de mon home, mais mme en incluant les chiers cachs avec -a je ne vois pas de chier appel .nanorc !
En eet, il se peut que le chier .nanorc n'existe pas chez vous. Si tel est le cas, Nano sera charg avec les options par dfaut.
Cration du .nanorc
Pas de .nanorc ? Pas de problme, il sut de le crer. On peut par exemple faire ceci :
nno Fnnor
Cette commande ouvre Nano. Comme le chier .nanorc n'existe pas, un document vide est ouvert (gure 13.10). Le chier .nanorc sera cr lorsque vous enregistrerez. 203
CHAPITRE 13.
Figure 13.10 Un .nanorc neuf (et vide). Notez que le nom du chier est dj indiqu
en haut de l'cran. Dans ce chier, vous devez crire une commande par ligne. Chaque commande commence par un set (pour activer) ou un unset (pour dsactiver) suivi de l'option qui vous intresse. Par exemple, pour activer la souris, crivez :
set mouse
Ainsi Nano sera automatiquement charg avec la prise en charge de la souris. Vous n'aurez pas besoin de rcrire systmatiquement le paramtre -m qu'on a vu tout l'heure. On peut faire de mme pour viter d'avoir taper chaque fois les paramtres -i et -A avec d'autres sries de set. Au nal, on crira ceci :
set mouse set utoindent set smrthome
Enregistrez le chier avec Ctrl + O. Comme vous avez dj mentionn le nom du chier en paramtre lors de l'ouverture de Nano, celui-ci sera automatiquement crit pour vous (gure 13.11). Vous pouvez ensuite faire Ctrl + X pour quitter Nano. Je vous rappelle que pour que ces options soient prises en compte, il faut dmarrer une nouvelle session de Nano (c'est 204
.NANORC
Normalement, ce chier existe dj. Comme vous pouvez le constater sur la gure 13.12, il est bien rempli.
2. Attention : il n'y a pas de point devant, cette fois.
205
CHAPITRE 13.
Supprimez juste le # pour dcommenter la ligne et donc pour activer l'indentation automatique pour tous les utilisateurs.
set utoindent
Vous pouvez parcourir le chier la recherche d'options intressantes que vous voulez activer. Vers la n, vous verrez une section appele color setup , qui commence par ces lignes-l :
55 xnor files 5 inlude 4GusrGshreGnnoGnnorFnnor4
206
.BASHRC
Je vous invite dcommenter toutes les lignes d'include. Cela permettra d'activer la coloration intelligente de vos chiers selon leur type. Vous pourrez ainsi avoir des chiers HTML colors, des chiers C colors, des chiers nanorc colors, etc. Enregistrez le chier puis quittez Nano.
Si vous avez une erreur lors de l'enregistrement, cela signie que vous n'avez pas ouvert le chier en root. Seul root a le droit de modier ce chier. Fermez Nano et relancez-le avec un sudo cette fois.
207
CHAPITRE 13.
Rendez-vous plus bas dans le chier, jusqu' ce que vous tombiez sur ces lignes :
5 set fny prompt @nonEolorD unless we know we 4wnt4 olorA se 46iw4 in xtermEolorA Ia96{deinhrootXC@6deinhrootA}HQQHIYQPmudhHQQHHmX HQQHIYQRmwHQQHHm6 9 YY BA Ia96{deinhrootXC@6deinhrootA}udhXw6 9 YY es 5 gomment in the ove nd unomment this elow for olor prompt 5 Ia96{deinhrootXC@6deinhrootA}HQQHIYQPmudhHQQHHmX HQQHIYQRmwHQQHHm6 9
Dans les commentaires, on vous dit que vous pouvez activer l'invite de commandes colore en commentant les lignes du dessus et en dcommentant la dernire ligne. Rajoutez donc un # devant les deux premiers PS1, et enlevez le # devant le dernier PS1 pour que la coloration de l'invite de commandes puisse fonctionner :
5 set fny prompt @nonEolorD unless we know we 4wnt4 olorA se 46iw4 in xtermEolorA 5 Ia96{deinhrootXC@6deinhrootA}HQQHIYQPmudhHQQHHmX HQQHIYQRmwHQQHHm6 9 YY BA 5 Ia96{deinhrootXC@6deinhrootA}udhXw6 9 YY es 5 gomment in the ove nd unomment this elow for olor prompt Ia96{deinhrootXC@6deinhrootA}HQQHIYQPmudhHQQHHmX HQQHIYQRmwHQQHHm6 9
Enregistrez. Il faudra ouvrir une nouvelle console pour que la modication soit prise en compte an de proter d'une invite de commandes en couleurs. Si vous tes en forme, vous pouvez diter la ligne que vous venez de dcommenter :
Ia96{deinhrootXC@6deinhrootA}HQQHIYQPmudhHQQHHmX HQQHIYQRmwHQQHHm6 9
C'est en fait elle qui indique ce que l'invite de commandes doit acher. Les squences de type \033 servent paramtrer la couleur (ce n'est pas simple, je vous l'accorde). 208
.BASHRC
Le symbole \u au milieu indique le nom de l'utilisateur (mateo21 par exemple) et \h indique le nom de la machine hte (mateo21-desktop). Vous pouvez reprer dans cette ligne le @ qui spare les deux, le : , le $ , etc. Vous pouvez essayer de personnaliser un peu ces lments ainsi que leur ordre si a vous amuse 3 .
Celui-ci active la coloration des rsultats d'un ls chaque fois que vous tapez ls. En fait, ls est systmatiquement et automatiquement transform par la console en ls --color=auto. C'est quand mme plus rapide que de rcrire sans cesse ces paramtres. Il y a un autre alias que j'ai l'habitude d'utiliser, c'est ll (deux fois la lettre L minuscule). Cela permet de faire un ls en mode dtaill. Personnellement, j'ai un peu complt l'alias pour utiliser plus d'options la fois, comme j'en ai parl dans le chapitre sur ls :
lis lla9ls Elerth9
3. Mais faites quand mme attention ne pas mettre le bazar l-dedans, hein. ;-)
209
CHAPITRE 13.
. . . signie que la commande ll fera appel ls avec les options qui permettent d'acher le dtail de chaque chier, d'acher les chiers cachs, d'acher les chiers dans l'ordre inverse de dernire modication (le chier le plus rcent sera en bas) et d'acher des tailles de chiers lisibles pour un humain (-h). La commande ls appellera automatiquement l'alias ls --color=auto, ce qui fait qu'un ll sera aussi color. Bref, c'est un peu un alias en chane.
Si vous tapez la commande alias dans la console, vous verrez la liste de tous les alias dnis pour votre utilisateur.
Vous pouvez vous aussi dnir vos propres alias. Comme vous pouvez le voir, c'est trs simple car cela fonctionne sur le modle :
lis noma9ommnde9
Attention ne pas mettre d'espace autour du symbole = . On peut par exemple en proter pour scuriser un peu nos rm pour viter que l'on puisse supprimer tout le systme depuis la racine /. Il y a en eet un paramtre de scurit disponible avec rm : --preserve-root. Mais ce serait un peu long de l'crire chaque fois et on risquerait surtout d'oublier. En dnissant un alias sur rm, vous ne pourrez pas oublier :
lis rma9rm EEpreserveEroot9
Ne testez pas l'ecacit de cette commande en faisant un rm -rf / en root ! En eet, il faut relancer une console pour que les modications soient prises en compte, et si vous avez fait une faute de frappe dans votre alias, vous ne serez pas protgs. . . mais pendant ce temps votre systme sera dtruit, lui ! Bref, mme pour vrier , ne vous amusez pas utiliser le rm de la mort. . .
.BASHRC
Les lments du bashrc personnel ont la priorit sur ceux du bashrc global. Si un mme alias est dni dans les deux, c'est celui du bashrc personnel qui sera pris en compte.
Et aussi. . . le .profile
De mme qu'il existe un ~/.bashrc et un /etc/bash.bashrc, il existe un ~/.profile et un /etc/profile. Quelle est la dirence ? En gros, le .prole est lu chaque nouvelle console dans laquelle vous vous loggez (vous rentrez votre login / mot de passe). C'est le cas des consoles que vous ouvrez avec Ctrl + Alt + F1 F6 (tty1 tty6). Le .bashrc est lu lorsque vous ouvrez une console dans laquelle vous ne vous loggez pas. C'est le cas des consoles que vous ouvrez en mode graphique (Terminal sous Gnome, Konsole sous KDE). C'est un peu compliqu pour pas grand-chose au nal. Dans la pratique, le .profile fait par dfaut appel au .bashrc. . . Donc il sut d'diter votre .bashrc et vous modierez ainsi les options de toutes vos consoles : celles avec et sans login. Voil pourquoi je vous ai fait diter ds le dbut le .bashrc. ;-) Pour bien comprendre comment a fonctionne, tout est rsum dans le schma de la gure 13.13.
CHAPITRE 13.
On a, sur ce schma, deux types de shell possibles : soit on a ouvert un shell qui demande un mot de passe et dans ce cas, c'est le .profile qui est lu pour la conguration ; soit on a ouvert un shell qui ne demande pas de mot de passe (c'est le cas d'une console en mode graphique en gnral) et dans ce cas-l, c'est le .bashrc qui servira la conguration. La particularit, comme le montre le schma, c'est que le .profile fait appel au .bashrc. . . ce qui signie que vous pouvez faire toutes vos congurations dans le .bashrc pour qu'elles soient valables quel que soit le type de shell que vous ouvrez.
En rsum
Un diteur de texte est un programme qui ouvre des chiers texte (un peu comme Bloc-Notes sous Windows). On en a rgulirement besoin sous Linux pour modier des chiers de conguration, par exemple. Il existe de nombreux diteurs de texte en console qui peuvent tre trs complets, comme Vim et Emacs. L'diteur Nano est un des diteurs en console les plus simples utiliser ; nous commenons donc par dcouvrir celui-ci. On utilise plusieurs raccourcis clavier dans un diteur de texte comme Nano. Ctrl + W lance une recherche, Ctrl + O enregistre le chier, Ctrl + X permet de quitter, etc. On peut utiliser Nano pour modier son chier de conguration .bashrc et personnaliser sa console. On peut notamment s'en servir pour colorer l'invite de commandes et crer des alias.
212
Chapitre
14
Dicult :
uand vous tes sous Windows et que vous voulez tlcharger un nouveau programme, que faites-vous ? En gnral une petite recherche sur un moteur de recherche, un tour sur les sites de tlchargement comme telecharger.com, clubic.com. . . et vous trouvez votre bonheur. Vous rcuprez un programme d'installation, vous faites Suivant , Suivant , Suivant , Terminer et c'est install. Parfois, il faut rpondre des questions un peu techniques comme Dans quel rpertoire voulez-vous installer ce programme ? . Sous Linux (et notamment sous Ubuntu), a ne fonctionne pas du tout comme a : c'est encore plus simple. Mieux : vous allez vite vous rendre compte que c'est un vrai plaisir d'installer de nouveaux programmes et que c'est mme un des points forts d'un systme comme Ubuntu par rapport Windows. Vous allez voir.
213
CHAPITRE 14.
APT-GET
Mais alors. . . un paquet .deb, c'est un peu comme un programme d'installation .exe sous Windows, non ?
a y ressemble, mais en fait a fonctionne trs diremment. Je citerai deux dirences notables : il y a une gestion des dpendances du programme ; on n'a pas besoin de faire une recherche sur un moteur de recherche pour trouver un .deb. Tous les .deb sont rassembls au mme endroit sur un mme serveur appel dpt (repository ). Ces deux points mritent plus d'explications. Dans un premier temps nous allons voir ce que sont les dpendances ; dans un second temps, nous traiterons les dpts.
214
LES DPTS
On dit que les programmes dpendent d'autres programmes pour fonctionner : ils ont des dpendances. Par exemple, le programme de dessin The GIMP (quivalent de Photoshop) ne peut pas fonctionner seul. Il dpend de bibliothques de lecture des images (qui lui disent comment lire une image JPEG) par exemple. Parfois, ces dpendances ont elles-mmes des dpendances !
Vous avez certainement dj rencontr un peu ce problme sous Windows. Par exemple, quand vous installez un jeu, on vous dit Il faut installer Direct X avant de pouvoir jouer ce jeu .
Heureusement, le systme de paquets Debian est intelligent. Chaque paquet indique de quels autres paquets il dpend. Cela permet au systme d'aller rcuprer les dpendances manquantes automatiquement si besoin est. Du coup, vous n'avez plus qu' dire Je veux installer Nano et le systme ira chercher toutes les dpendances manquantes tout seul !
Les dpts
Comme je vous l'ai dit un peu plus haut, tous les paquets sont regroups au sein d'un mme endroit appel dpt. Il s'agit d'un serveur qui propose tous les paquets qui existent (ou presque), ce qui simplie grandement vos recherches. Sous Windows, les programmes sont parpills aux quatre coins du Net. Sous Linux, on a dcid de ne pas refaire la mme erreur. On a choisi de mettre tout le monde d'accord et de placer tous les programmes (paquets) au mme endroit.
Ceci est possible en partie grce au fait que la plupart des programmes sous Linux sont libres. En eet, les programmes tant libres , tout le monde est autoris les diuser ; a ne pose donc aucun problme de les voir tous rassembls au mme endroit. Sous Windows, la majorit des programmes tant propritaire, leurs auteurs n'auraient jamais donn leur accord pour que ceux-ci soient diuss au mme endroit (gratuitement, qui plus est).
La notion de dpt
L'endroit o tous les paquets se trouvent est appel dpt (repository en anglais).
Si tout le monde va chercher ses paquets sur un mme dpt, a ne risque pas d'engorger le pauvre serveur qui les distribue ?
Bonne remarque, vous avez tout fait raison. On peut certes mettre un gros serveur 215
CHAPITRE 14.
APT-GET
avec une grosse bande passante (qui permet plusieurs centaines de personnes de tlcharger en mme temps), mais on peut dicilement imaginer que tous les linuxiens de la plante aillent se servir au mme endroit au mme moment ! C'est pour cela qu'il existe en fait un grand nombre de dpts. La plupart proposent exactement les mmes paquets (les dpts sont donc des copies les uns des autres). Certains dpts spciaux proposent toutefois des programmes que l'on ne trouve nulle part ailleurs, mais il est rare que l'on ait besoin de se servir dans ces dpts.
En rgle gnrale, avoir un seul bon dpt sut installer la plupart des programmes qui existent sous Linux !
Schmatiquement, je reprsenterais les dpts comme sur la gure 14.2.
LES DPTS
ment vite). En France, par dfaut, Ubuntu utilise le dpt fr.archive.ubuntu.com. Ce n'est pas toujours une bonne ide de garder le dpt par dfaut car en cas de nouvelle version d'Ubuntu et de ses logiciels, celui-ci est surcharg et devient alors trs lent. Si vous tes chez Free, je vous recommande d'utiliser le dpt de Free. Si vous tes chez Wanadoo / Orange, je vous recommande d'utiliser le dpt Oleane (appartenant Orange). Nous allons voir comment changer de dpt.
Ce chier ne peut tre modi que par root, l'administrateur de la machine. Pour que vous puissiez modier ce chier, il faut donc passer root. Pour cela, vous avez deux possibilits. Soit vous faites un sudo juste avant :
sudo nno GetGptGsouresFlist
. . . et vous modierez le chier en tant que root. Soit vous passez root dnitivement en faisant sudo su d'abord. Le chier que vous avez devrait ressembler ceci :
5 ee httpXGGhelpFuuntuFomGommunityGpgrdexotes for how to upgrde to 5 newer versions of the distriutionF de httpXGGfrFrhiveFuuntuFomGuuntuG hrdy min restrited deEsr httpXGGfrFrhiveFuuntuFomGuuntuG hrdy min restrited 55 wjor ug fix updtes produed fter the finl relese of the 55 distriutionF de httpXGGfrFrhiveFuuntuFomGuuntuG hrdyEupdtes min restrited deEsr httpXGGfrFrhiveFuuntuFomGuuntuG hrdyEupdtes min restrited
2. J'avais tout calcul, qu'est-ce que vous croyez ?
217
CHAPITRE 14.
APT-GET
55 xFfF softwre from this repository is ixsiv xyih y the untu 55 temD nd my not e under free lieneF lese stisfy yourself s to 55 your rights to use the softwreF elsoD plese note tht softwre in 55 universe svv xy reeive ny review or updtes from the untu seurity 55 temF de httpXGGfrFrhiveFuuntuFomGuuntuG hrdy universe deEsr httpXGGfrFrhiveFuuntuFomGuuntuG hrdy universe 55 xFfF softwre from this repository is ixsiv xyih y the untu 55 temD nd my not e under free lieneF lese stisfy yourself s to 55 your rights to use the softwreF elsoD plese note tht softwre in 55 multiverse svv xy reeive ny review or updtes from the untu 55 seurity temF de httpXGGfrFrhiveFuuntuFomGuuntuG hrdy multiverse deEsr httpXGGfrFrhiveFuuntuFomGuuntuG hrdy multiverse 55 nomment the following two lines to dd softwre from the 9kports9 55 repositoryF 55 xFfF softwre from this repository my not hve een tested s 55 extensively s tht ontined in the min releseD lthough it inludes 55 newer versions of some pplitions whih my provide useful feturesF 55 elsoD plese note tht softwre in kports svv xy reeive ny review 55 or updtes from the untu seurity temF 5 de httpXGGfrFrhiveFuuntuFomGuuntuG hrdyEkports min restrited universe multiverse 5 deEsr httpXGGfrFrhiveFuuntuFomGuuntuG hrdyEkports min restrited universe multiverse de httpXGGseurityFuuntuFomGuuntu hrdyEseurity min restrited deEsr httpXGGseurityFuuntuFomGuuntu hrdyEseurity min restrited de httpXGGseurityFuuntuFomGuuntu hrdyEseurity universe deEsr httpXGGseurityFuuntuFomGuuntu hrdyEseurity universe de httpXGGseurityFuuntuFomGuuntu hrdyEseurity multiverse deEsr httpXGGseurityFuuntuFomGuuntu hrdyEseurity multiverse
Les lignes commenant par un # sont des lignes de commentaires. Elles seront ignores. Normalement, chaque ligne du chier commence par une de ces deux directives : deb : pour tlcharger la version compile (binaire) des programmes. C'est ce que vous voudrez faire dans la plupart des cas car c'est la version prte l'emploi ; deb-src : permet de rcuprer le code source du programme. Gnralement, vous n'en avez pas besoin, sauf si vous tes curieux et que vous voulez voir la source d'un programme 3 . A priori seules les lignes deb nous intressent. On pourrait mme supprimer (ou commenter) les lignes deb-src, rcuprer les sources n'ayant aucun intrt pour nous. Voici une ligne type :
3. C'est l'avantage des logiciels libres de pouvoir consulter la source des programmes !
218
LES DPTS
En premier paramtre, on a l'adresse du dpt. Ici, le dpt franais par dfaut est http://fr.archive.ubuntu.com/ubuntu/. Ensuite, on a le nom de la version de la distribution qu'on utilise, hardy dans ce cas. Enn, le dernier paramtre (et tous les paramtres suivants s'il y en a) correspond la section du dpt dans laquelle vous voulez regarder. Ouf. . . c'est un peu compliqu, tout a. En fait, la seule chose que vous devriez avoir faire, c'est remplacer toutes les adresses (http. . .) par celle du nouveau dpt que vous voulez utiliser.
CHAPITRE 14.
APT-GET
CHAPITRE 14.
APT-GET
Je vous ai propos de changer de dpt mais sachez que ce n'est pas obligatoire, vous pouvez vous contenter de celui par dfaut. Sous Ubuntu, on peut utiliser un programme graphique qui gre les paquets pour nous : nous avions justement dcouvert la logithque Ubuntu au dbut de ce cours. Ici, nous nous intressons aux manipulations en console. Les deux programmes console de gestion des paquets les plus connus sont : apt-get ; aptitude. Lequel des deux utiliser ? Le premier est srement le plus clbre ; le second est gnralement reconnu comme tant plus ecace lors de la dsinstallation de paquets (il supprime aussi les dpendances inutilises). Cependant apt-get sous Ubuntu a volu aussi et peut supprimer les dpendances inutilises. Aprs, c'est un peu une question d'habitude. Pour ma part, j'ai toujours t habitu apt-get, c'est donc celui que j'utilise et que je vais vous montrer. Que vous utilisiez l'un ou l'autre ne fera pas beaucoup de dirence. Nous devons gnralement suivre trois tapes pour tlcharger un paquet : apt-get update (optionnel) : pour mettre notre cache jour si ce n'est pas dj fait ; apt-cache search monpaquet (optionnel) : pour rechercher le paquet que nous voulons tlcharger si nous ne connaissons pas son nom exact ; apt-get install monpaquet : pour tlcharger et installer notre paquet. C'est trs simple, vous allez voir. Nous verrons aussi comment supprimer un paquet et comment mettre tous nos paquets jour en une seule commande !
apt-get update
Commenons par la mise jour du cache des paquets (apt-get update). Cela correspond tlcharger la nouvelle liste des paquets proposs par le dpt. Toutefois, il n'est pas ncessaire de mettre jour son cache chaque fois que l'on veut tlcharger un paquet.
APT-GET UPDATE
ptEget updte
223
CHAPITRE 14.
APT-GET
etteint ftpXGGftpFfreeFfr hrdyEupdtesGrestrited oures eption de X IP ftpXGGftpFfreeFfr hrdyEseurityGrestrited kges SWWHf eption de X IQ ftpXGGftpFfreeFfr hrdyEseurityGmin kges IPHkf eption de X IR ftpXGGftpFfreeFfr hrdyEseurityGrestrited oures WSTf eption de X IS ftpXGGftpFfreeFfr hrdyEseurityGuniverse kges UVDTkf eption de X IT ftpXGGftpFfreeFfr hrdyEseurityGuniverse oures IIDVkf eption de X IU ftpXGGftpFfreeFfr hrdyEseurityGmultiverse kges SQWSf eption de X IV ftpXGGftpFfreeFfr hrdyEseurityGmultiverse oures IHRPf QVPko reptionns en Us @SHDIkoGsA veture des listes de pquetsFFF pit
Voil : a fait un peu peur la premire fois mais en gnral, c'est assez rapide. Je vous rappelle que vous n'avez pas besoin d'excuter cette commande chaque fois que vous voulez installer un paquet mais seulement de temps en temps pour tre srs d'avoir la liste la plus jour possible.
apt-cache search
: rechercher un paquet
moins que vous ne connaissiez dj le nom exact du paquet que vous voulez, il va falloir eectuer une petite recherche. On utilise pour cela la commande suivante :
ptEhe serh votrereherhe
Cette commande eectue une recherche de paquet dans votre cache. Cela vite d'avoir aller sur Internet pour faire la recherche, ce qui aurait t lent. Bon ! Que veut-on tlcharger ? Un diteur de texte ? Un navigateur ? Allez : pour s'amuser, je vous propose de rechercher un jeu, par exemple un jeu de casse-briques (breakout en anglais). Faites la recherche suivante :
rootdmteoPIEdesktopX~5 ptEhe serh rekout riquolo E pst ped Qd frekout riquoloEdt E pst ped Qd frekout dt files iruslinux E he lowns re trying to pop lloons to sore points3 iruslinuxEdt E dt files for iruslinux gnomeErekout E glone of the lssi gme frekoutD written for qxywi lrekoutP E e llEndEpddle gme with nie grphis lrekoutPEdt E e llEndEpddle gme with nie grphis @hee psviA lifreeoH E preefof es lifreeoHEdev E preefof es E development files tenollz E reking lok gme ported from the emig pltform
La commande apt-cache search breakout a list tous les paquets qui avaient un rapport avec les casse-briques. gauche vous avez le nom du paquet, droite une courte description. 224
APT-GET INSTALL
: INSTALLER UN PAQUET
Si vous voulez une plus ample description d'un paquet, utilisez apt-cache show nomdupaquet. Exemple : apt-cache show lbreakout2.
apt-get install
: installer un paquet
Pour ma part, j'aime beaucoup le jeu lbreakout2 (gure 14.8). Je vous propose donc de le tlcharger, ce qui se fait trs simplement (toujours en tant que root, rajoutez un sudo devant la commande si vous n'tes pas dj root) :
ptEget instll lrekoutP
Astuce : vous pouvez installer plusieurs paquets d'un coup en les listant un un : apt-get install paquet1 paquet2 paquet3
Essayons donc d'installer lbreakout2 : 225
CHAPITRE 14.
APT-GET
rootdmteoPIEdesktopX~5 ptEget instll lrekoutP veture des listes de pquetsFFF pit gonstrution de l9rre des dpendnes veture de l9informtion d9ttFFF pit ves pquets supplmentires suivnts seront instlls X lrekoutPEdt lisdlEmixerIFP lismpegH ves xyie pquets suivnts seront instlls X lrekoutP lrekoutPEdt lisdlEmixerIFP lismpegH H mis jourD R nouvellement instllsD H enlever et ISQ non mis jourF sl est nessire de prendre PWRQko dns les rhivesF eprs dpquetgeD SQSVko d9espe disque supplmentires seront utilissF ouhitezEvous ontinuer yGn c y eption de X I ftpXGGftpFfreeFfr feistyGmin lismpegH HFRFSCvsPHHQHVPREIFWuildI IHSkf eption de X P ftpXGGftpFfreeFfr feistyGmin lisdlEmixerIFP IFPFTEIFIuildI IRSkf eption de X Q ftpXGGftpFfreeFfr feistyGuniverse lrekoutPEdt PFSFPEPFIuuntuI PRRRkf eption de X R ftpXGGftpFfreeFfr feistyGuniverse lrekoutP PFSFPEPFIuuntuI PRWkf PWRQko reptionns en Ts @RVRkoGsA letion du pquet lismpegH prdemment dsletionnF @veture de l se de donnesFFF IPQQSH fihiers et rpertoires dj instllsFA hpquetge de lismpegH @ prtir de FFFGlismpegHHFRFSCvsPHHQHVPREIFWuildImdTRFdeA FFF letion du pquet lisdlEmixerIFP prdemment dsletionnF hpquetge de lisdlEmixerIFP @ prtir de FFFGlisdlEmixerIFPIFPFTEIFIuildImdTRFdeA FFF letion du pquet lrekoutPEdt prdemment dsletionnF hpquetge de lrekoutPEdt @ prtir de FFFGlrekoutPEdtPFSFPEPFIuuntuIllFdeA FFF letion du pquet lrekoutP prdemment dsletionnF hpquetge de lrekoutP @ prtir de FFFGlrekoutPPFSFPEPFIuuntuImdTRFdeA FFF rmtrge de lismpegH @HFRFSCvsPHHQHVPREIFWuildIA FFF rmtrge de lisdlEmixerIFP @IFPFTEIFIuildIA FFF rmtrge de lrekoutPEdt @PFSFPEPFIuuntuIA FFF rmtrge de lrekoutP @PFSFPEPFIuuntuIA FFF
226
APT-GET INSTALL
: INSTALLER UN PAQUET
avant de l'excuter.
E: Impossible d'ouvrir le fichier verrou /var/lib/dpkg/lock - open (13 Permission non accorde) E: Unable to lock the administration directory (/var/lib/dpkg/), are you root? . . . c'est que vous n'avez pas excut la commande en tant que root. Pensez passer root (en utilisant sudo)
Il s'en est pass des choses, dites donc ! Comme vous pouvez le voir, au dbut apt-get a vri si le paquet existait et les dpendances dont il avait besoin. Il se trouve que lbreakout2 avait besoin de dpendances qu'on n'a pas, comme libsdlmixer-1.2 par exemple. C'est pour cela qu'on nous a demand conrmation au milieu :
Souhaitez-vous continuer [O/n] ?
Rpondez par un O majuscule (comme Oui ) et tapez Entre pour que l'installation se poursuive. C'est alors que la magie d'apt-get opre : le programme va aller tlcharger tout seul le paquet sur le dpt ainsi que toutes les dpendances dont il a besoin et que nous n'avons pas. Puis il dpaqute les chiers qui taient contenus l'intrieur du paquet, les installe et eectue les paramtrages tout seul. Ce qui est fort l-dedans, c'est qu'apt-get ne vous demande rien ! Il installe tout ce qu'il faut tout seul, dans les bons rpertoires, et cre mme le raccourci pour lancer le jeu dans la section Jeux ! Vriez par vous-mmes. Le menu des applications d'Ubuntu comporte dsormais une section Jeux (qu'il a cre si elle n'existait pas) et possde un raccourci vers le jeu que nous venons d'installer (gure 14.9).
CHAPITRE 14.
APT-GET
14.10, vous pouvez voir OpenArena, bas sur le clbre jeu Quake III Arena dont le code source est devenu libre.
apt-get autoremove
: supprimer un paquet
Si vous voulez dsinstaller un paquet, vous pouvez utiliser la commande apt-get remove :
ptEget remove lrekoutP
Le paquet sera alors dsinstall de votre ordinateur. Toutefois, cela ne supprime pas les dpendances du paquet devenues inutiles. Pour demander apt-get de supprimer aussi les dpendances inutiles, on utilise autoremove :
ptEget utoremove lrekoutP
4. Notez toutefois qu'il est fortement conseill d'avoir install les pilotes de votre carte graphique avant d'y jouer.
228
APT-GET UPGRADE
Faisons un autoremove, comme a nous serons srs de librer un maximum d'espace disque.
rootdmteoPIEdesktopX~5 ptEget utoremove lrekoutP veture des listes de pquetsFFF pit gonstrution de l9rre des dpendnes veture de l9informtion d9ttFFF pit ves pquets suivnts ont t utomtiquement instlls mis ne sont plus nessires X lisdlEmixerIFP lismpegH ves pquets suivnts seront ixvi X lrekoutP lrekoutPEdt lisdlEmixerIFP lismpegH H mis jourD H nouvellement instllsD R enlever et H non mis jourF sl est nessire de prendre Ho dns les rhivesF eprs dpquetgeD SQSVko d9espe disque seront lirsF ouhitezEvous ontinuer yGn c
apt-get analyse le paquet, vrie les dpendances qu'il peut supprimer sans risque
(c'est--dire les dpendances qui ne sont plus utilises par aucun autre paquet) et calcule la taille d'espace disque libr (un peu plus de 5 Mo dans mon cas). Faites O pour conrmer que vous voulez bien dsinstaller le paquet et ses dpendances. Vous voyez alors les paquets se faire dsinstaller par apt-get :
uppression uppression uppression uppression de de de de lrekoutP FFF lrekoutPEdt FFF lisdlEmixerIFP FFF lismpegH FFF
apt-get upgrade
Une autre fonctionnalit particulirement gniale d'apt-get est sa capacit mettre jour tous les paquets installs sur votre systme d'un seul coup. Le programme ira chercher les nouvelles versions de tous vos programmes et les mettra jour si une nouvelle version est disponible :
ptEget upgrde
229
CHAPITRE 14.
APT-GET
Pensez faire un apt-get update pour mettre jour le cache des paquets sur votre machine avant de lancer un upgrade. En eet, apt-get compare la version de vos paquets installs avec ceux prsents dans le cache. Si votre cache est ancien , apt-get se dira Oh bah, il n'y a rien de nouveau, pas besoin d'une mise jour . Veillez donc faire rgulirement un apt-get update pour tre 100 % srs que votre cache est jour.
On vous demandera une conrmation aprs avoir list tous les paquets qui ont besoin d'une mise jour. Vous n'avez pas besoin de faire autre chose. Tous vos paquets installs seront mis jour (a peut tre un peu long, par contre). Si tous vos paquets sont dj dans leur version la plus rcente, vous verrez le message suivant :
rootdmteoPIEdesktopX~5 ptEget upgrde veture des listes de pquetsFFF pit gonstrution de l9rre des dpendnes veture de l9informtion d9ttFFF pit H mis jourD H nouvellement instllsD H enlever et H non mis jourF
Tous ces 0 de la dernire ligne nous indiquent que rien ne s'est pass car il n'y avait rien faire. Cela signie que votre systme est jour.
Il est conseill de faire un apt-get upgrade rgulirement pour avoir le systme le plus jour possible. Cela vous permet de bncier des dernires fonctionnalits des logiciels, mais cela corrige aussi les failles de scurit qui auraient pu tre dcouvertes dans les programmes (et on en trouve tous les jours, mme dans les logiciels libres !).
En rsum
La plupart des distributions Linux proposent un moyen centralis de tlcharger et d'installer des logiciels facilement. L'installation de programmes y est gnralement beaucoup plus simple que sous Windows ! Sous Ubuntu, on peut utiliser des interfaces graphiques pour tlcharger et installer des logiciels. En console, on fait appel au programme apt-get. On tlcharge les programmes depuis des serveurs (fournis par Ubuntu, votre fournisseur d'accs ou une universit) qui font oce de dpts. apt-get update met jour la liste des programmes (appels paquets ) qui existent. apt-cache search permet de rechercher dans la liste des paquets. apt-get install tlcharge et installe un paquet. apt-get upgrade met jour tous les paquets installs. apt-get autoremove permet de supprimer un paquet.
230
Chapitre
15
Dicult :
uand on vient de Windows, on n'a pas trop l'habitude de lire des documentations. Parfois les logiciels sont livrs avec des modes d'emploi, mais honntement, qui ici prend la peine de les lire ? Sous Linux, lire la documentation doit devenir un rexe. En eet, bien que cela fasse un peu peur au premier abord, la documentation est vraiment le meilleur endroit pour en savoir plus sur les commandes que vous utilisez. Les livres que j'cris ne pourront jamais rivaliser avec la documentation. Je peux vous montrer les commandes et les paramtres qui me semblent les plus utiles, mais pour connatre certains paramtres dont vous avez besoin moins souvent, vous n'y couperez pas : vous aurez besoin de lire la doc. Ce chapitre est justement l pour dmystier le manuel et vous apprendre le lire. C'est peut-tre un des chapitres les plus importants du cours, car si vous savez lire la doc, vous tes capables d'apprendre tout ce dont vous avez besoin. . . et vous pourrez donc tout faire !
231
CHAPITRE 15.
Le titre de ce chapitre est une insulte amicale entre linuxiens. C'est en gnral ce qu'on dit un dbutant qui pose trop de questions sur les forums alors que la rponse se trouve dans la doc. RTFM est une abrviation qui signie Read The Fucking Manual , ce qui se traduirait en franais par quelque chose comme Lis ce p*** de manuel . Mais oui, c'est amical ! Puisque je vous le dis. . .
man
La commande magique que nous allons exprimenter tout au long de ce chapitre est man, qui est l'abrviation de manual. La commande man s'utilise trs simplement : elle prend en paramtre le nom de la commande dont vous voulez lire la doc. Par exemple, si je veux tout savoir sur la commande mkdir, je dois crire :
mn mkdir
MAN
s'ache page par page, la manire de less qu'on a vue dans un chapitre prcdent.
Si comme moi vous avez ouvert votre manuel dans une console graphique, vous pouvez aussi utiliser la molette de la souris !
CHAPITRE 15.
SEE ALSO : cette section vous propose de voir aussi d'autres commandes en rapport avec celle que vous tes en train de regarder. C'est une section parfois intressante. Pour faire simple, les trois premires sections sont vraiment les plus importantes (NAME, SYNOPSIS et DESCRIPTION). Ce sont celles que nous regarderons dans la plupart des cas et c'est aussi pour cela qu'elles sont au dbut du manuel. ;-)
Le paquet installer est manpages-fr comme vous pouvez le voir. Maintenant, si vous tapez man mkdir, vous verrez la page s'acher en franais (gure 15.2).
Utiliser les pages du manuel en franais n'est pas recommand. En eet, ces pages ne sont parfois pas jour, certaines ne sont pas traduites, et seule la version anglaise est assure d'tre la plus jour et de comporter le moins d'erreurs. D'ailleurs, en parlant d'erreur cher lecteur, une faute d'orthographe s'est glisse dans la capture d'cran de la gure 15.2, sauras-tu la retrouver 2 ?
Dans la suite de ce livre, je considrerai que vous travaillez avec les pages du manuel en anglais. C'est vraiment ce que je recommande. Utilisez la version franaise uniquement
1. Rien n'est laiss au hasard, je vous l'ai dit. 2. crer des rpertoires parent... Ne sont-ils pas plusieurs, ces rpertoires ? Il manque un s parent !
234
COMPRENDRE LE
SYNOPSIS
Bien, les prsentations tant faites, passons la suite ! Nous allons apprendre lire la section SYNOPSIS, une des sections les plus importantes.
Comprendre le SYNOPSIS
Le SYNOPSIS est une des sections les plus importantes mais aussi une des plus diciles lire.
CHAPITRE 15.
raliser avec cette commande. Certains SYNOPSIS sont simples, d'autres plus compliqus. Je pense que le mieux est de voir des exemples pour bien comprendre comment a fonctionne.
man mkdir
Commenons par le man de mkdir. La section d'introduction du manuel nous dit mkdir - make directories , ce qui signie que mkdir sert crer des rpertoires.
SYNOPSIS
OPTION
et
DIRECTORY
sont
Les mots du SYNOPSIS crits en gras sont des mots taper tels quels. Les mots souligns, eux, doivent tre remplacs par le nom appropri. C'est logique : on doit bel et bien crire prcisment mkdir, par contre on ne doit pas crire DIRECTORY mais le nom du rpertoire. La prsence d'un paramtre soulign signie donc : Remplacez le mot soulign par un mot qui convient votre cas .
Exemples d'utilisation
D'aprs le SYNOPSIS, on doit au minimum crire le nom du dossier. Par exemple : 236
COMPRENDRE LE
SYNOPSIS
mkdir imges
Comme on l'a vu, les points de suspension aprs DIRECTORY nous indiquent qu'on peut rpter le nom du rpertoire autant de fois que l'on veut, ce qui nous permet d'en crer plusieurs d'un coup. On peut donc aussi utiliser mkdir comme ceci :
mkdir imges videos musiques
. . . ce qui aura pour eet de crer trois dossiers : images, videos et musiques. Maintenant, on peut aussi prciser des options facultatives. Ces options sont listes dans la section DESCRIPTION du man juste un peu plus bas :
higssyx grete the hsigy@iesAD if they do not lredy existF wndtory rguments tooF to long options re mndtory for short options
EmD EEmodeawyhi set file mode @s in hmodAD not arwx E umsk EpD EEprents no error if existingD mke prent diretories s needed EvD EEverose print messge for eh reted diretory ED EEontextag set the ivinux seurity ontext of eh g EEhelp disply this help nd exit EEversion output version informtion nd exit reted diretory to
Toutes ces options peuvent tre utilises la place de [OPTION] dans le SYNOPSIS. Par exemple, l'option -v (ou --verbose, c'est pareil mais plus long) ache un message aprs chaque rpertoire cr. On peut donc crire :
mkdir Ev imges videos musiques
Rsultat : 237
CHAPITRE 15.
mteoPIdmteoPIEdesktopX~Gtests6 mkdir Ev imges videos musiques mkdirX rtion du rpertoire imges9 mkdirX rtion du rpertoire videos9 mkdirX rtion du rpertoire musiques9
La commande nous informe maintenant de ce qu'elle fait. Sans le -v, la commande n'ache rien (on dit qu'elle est silencieuse). Vous remarquerez d'ailleurs qu'on retrouve l'option -v dans beaucoup de commandes. Elle a chaque fois la mme signication : elle demande la commande d'acher le dtail de ce qu'elle est en train de faire. On dit alors qu'on utilise la commande en mode verbeux (bavard), pour bien voir tout ce qu'elle fait.
man cp
Essayons une commande un peu plus complexe : cp. Je vous rappelle que cette commande sert copier des chiers et des rpertoires.
SYNOPSIS
COMPRENDRE LE
SYNOPSIS
Exemples d'utilisation
a fait beaucoup de faons d'utiliser cp, en fait. Si on se base sur la premire ligne, on peut juste crire :
p photoFjpg photoopieFjpg
. . . ce qui aura pour eet de crer la copie photo_copie.jpg. On peut aussi ajouter une ou plusieurs options. Pour connatre toutes les options disponibles, vous devrez lire la section DESCRIPTION. Pour cp, il y a beaucoup de choix comme vous pouvez le voir. Par exemple, on retrouve notre mode -v (verbeux) qui demande la commande de dtailler ce qu'elle fait. On pourrait aussi ajouter -i qui demande conrmation si le chier de destination existe dj. On peut donc faire :
p Evi photoFjpg photoopieFjpg
Dans mon cas, le chier photo_copie.jpg existait dj. L'ajout de l'option -i va me demander conrmation pour savoir si je veux bien craser le chier. Je peux rpondre par o ou n (pour oui ou non), ou y ou n (pour yes ou no ).
mteoPIdmteoPIEdesktopX~6 p Evi photoFjpg photoopieFjpg pX rser photoopieFjpg9c o photoFjpg9 Eb photoopieFjpg9
Comme le chier existait dj, on m'a demand conrmation. La dernire ligne est le rsultat du mode verbeux qu'on a demand. Bien. Tout a c'tait juste pour la premire ligne, dans le cas o l'on veut copier un chier. Essayons un peu ce que propose la seconde ligne : copier un ou plusieurs chiers dans un dossier.
p photoFjpg photoopieFjpg imgesG
L, on exploite la seconde faon d'utiliser cp (seconde ligne du SYNOPSIS). On copie deux chiers dans le sous-dossier images/. Bien entendu, comme l'indique le SYNOPSIS, on peut l encore utiliser des options, comme -v et -i que l'on vient de voir.
Mon conseil : vous vous demandez peut-tre comment je comprends la signication de chaque mot du SYNOPSIS. Par exemple, tait-il vident de savoir que SOURCE correspondait au chier que l'on voulait copier ? Si je sais tout a, c'est parce que j'ai lu attentivement le dbut de la section DESCRIPTION du man. Je vous recommande d'en faire de mme quelle que soit la commande que vous tes en train d'analyser.
239
CHAPITRE 15.
Cette phrase est claire, pour peu que l'on comprenne l'anglais. Elle signie que l'on peut copier le paramtre appel SOURCE vers DEST, ou encore (cas de la seconde ligne) plusieurs chiers SOURCE vers un rpertoire (DIRECTORY).
man apt-get
Plus joyeux encore : le SYNOPSIS de la commande apt-get (gure 15.5).
240
COMPRENDRE LE
SYNOPSIS
Vous remarquerez qu' l'intrieur les mots sont spars par des barres verticales | . Ces barres verticales signient OU , ce qui veut dire que vous devez mettre une et une seule option issue de la liste entre accolades. Parmi ces options possibles, il y en a que vous devez connatre maintenant, comme : update : met jour le cache des paquets disponibles sur votre ordinateur ; upgrade : met jour tous les paquets installs si une nouvelle version est disponible ; install paquet... : installe le ou les paquets demands. La prsence des points de suspension aprs paquet signie que vous pouvez indiquer plusieurs paquets installer d'un coup ; etc. Il y a bien d'autres mots cls utilisables. Pour voir la signication de chacun d'eux, je vous invite lire la section DESCRIPTION du man qui sert prcisment expliquer cela.
Exemples d'utilisation
Le SYNOPSIS indique donc qu'on doit choisir une des options entre accolades spares par des barres verticales. On peut donc crire :
ptEget instll monpquet
Ou encore :
ptEget updte
Ou encore :
ptEget utolen
En revanche, on ne peut pas utiliser simultanment deux options spares par une barre verticale :
sxihs X ptEget updte instll monpquet
Le SYNOPSIS nous avait bien dit : Utilisez update OU install OU upgrade (OU ...), mais pas deux lments de cette liste la fois . Souvenez-vous donc que les barres verticales signient OU et tout ira bien.
CHAPITRE 15.
souligne : remplacez le mot soulign par la valeur qui convient dans votre cas ; [-hvc] : toutes les options -h, -v et -c sont facultatives ; a|b : vous pouvez crire l'option a OU b , mais pas les deux la fois ; option... : les points de suspension indiquent que l'option peut tre rpte autant
apropos
Le man suppose que vous connaissez dj votre commande et que vous voulez en savoir plus. Mais si vous ne connaissez pas la commande, comment faites-vous ? C'est l que la commande apropos intervient. Vous lui donnez en paramtre un mot cl et elle va le rechercher dans les descriptions de toutes les pages du manuel. La commande apropos est donc un peu l'inverse de man : elle vous permet de retrouver une commande. Prenons un exemple : vous recherchez une commande (que vous avez installe) en rapport avec le son parce que vous aimeriez bien savoir comment modier le volume en console. Vous pouvez taper :
propos sound
. . . ce qui va rechercher toutes les commandes qui parlent de son (sound) dans leur page du manuel. Rsultat :
mteoPIdmteoPIEdesktopX~6 propos sound lstl @IA E dvned ontrols for eve soundrd driver lsmixer @IA E soundrd mixer for eve soundrd driverD with nurseFFF mixer @IA E ommndEline mixer for eve soundrd driver ply @IA E ommndEline sound reorder nd plyer for eve soundFFF reord @IA E ommndEline sound reorder nd plyer for eve soundFFF rtst @IA E pipe dt to sound devie soundonf @IA E utility to red nd hnge the user9s eve lirry onFFF
gauche la commande, droite l'extrait de sa courte description dans laquelle apropos a trouv le mot que vous recherchiez. Il se trouve que ce que je cherchais tait alsamixer (gure 15.6). Et zou ! :-)
lsmixer
Et si vous voulez en savoir plus sur la commande alsamixer, vous savez maintenant comment faire ! 242
Son SYNOPSIS, prsent sur la gure 15.7, est ridiculement simple. Pfeuh ! Mme pas drle.
243
CHAPITRE 15.
244
hek E erify tht there re no roken dependenies yptionsX Eh his help textF Eq voggle output E no progress inditor Eqq xo output exept for errors Ed hownlod only E do xy instll or unpk rhives Es xoEtF erform ordering simultion Ey essume es to ll queries nd do not prompt Ef ettempt to orret system with roken dependenies in ple Em ettempt to ontinue if rhives re unlotle Eu how list of upgrded pkges s well E fuild the soure pkge fter fething it E how verose version numers Eac ed this onfigurtion file Eoac et n ritrry onfigurtion optionD eg Eo dirXXheaGtmp ee the ptEget@VAD souresFlist@SA nd ptFonf@SA mnul pges for more informtion nd optionsF his e hs uper gow owersF
Le -h est parfois un bon complment au man si vous n'arrivez pas comprendre comment utiliser la commande. On y trouve parfois des informations utiles comme ici : The most frequently used commands are update and install , ce qui signie que l'on utilise le plus souvent apt-get avec les paramtres update et install (et c'est vrai).
Parfois, il n'y a pas de page de manuel pour une commande (man ne fonctionne pas pour cette dernire) mais le -h ou le --help fonctionne. Pensez-y !
La commande whatis
La commande whatis est une sorte de man trs allg. Elle donne juste l'en-tte du manuel pour expliquer en deux mots quoi sert la commande. Par exemple pour mkdir :
whtis mkdir
a vous permet d'viter de sortir l'artillerie lourde juste pour savoir quoi sert la commande.
mteoPIdmteoPIEdesktopX~6 whtis mkdir mkdir @IA E mke diretories
245
CHAPITRE 15.
En rsum
Sous Linux, toutes les commandes et leurs paramtres sont documents dans le manuel. Il est recommand de lire le manuel chaque fois que vous avez des questions sur une commande car la rponse s'y trouve la plupart du temps. On fait appel au manuel avec la commande man suivie du nom de la commande sur laquelle on veut avoir plus d'informations. Par exemple : man mkdir. Dans le manuel, on se dplace avec les touches ches ou Page Up et Page Down, on fait une recherche avec la touche / (slash) et on quitte avec la touche Q. Le manuel d'une commande commence toujours par son SYNOPSIS : c'est un rsum des direntes manires d'utiliser la commande. Les options facultatives sont crites entre crochets. Pour trouver une commande correspondant un certain usage, utilisez apropos. Ainsi, apropos sound achera toutes les commandes ayant un rapport avec le son.
246
Chapitre
16
Dicult :
ous Linux, les chiers sont organiss d'une faon assez particulire. Nous l'avons vu en achant la liste des rpertoires la racine avec un ls /, il y a une foule de dossiers aux noms assez varis : var, opt, etc, bin, dev. . . Une partie de ces rpertoires est l pour des raisons historiques, depuis l'poque d'Unix. Le problme, c'est qu'il peut tre dicile de retrouver le chier dont on a besoin dans cette foule de rpertoires. Pas de panique ! On dispose heureusement sous Linux d'outils trs puissants pour rechercher un chier sur le disque dur. Certains d'entre eux sont trs rapides, d'autres plus lents mais aussi plus complets. Partons la recherche de ces chiers !
247
CHAPITRE 16.
locate
La premire faon d'eectuer une recherche que nous allons voir est de loin la plus simple. La commande s'appelle locate ( localiser ). Elle est trs rapide.
Utiliser locate
Son utilisation est intuitive, il sut d'indiquer le nom du chier que vous voulez retrouver. Par exemple :
mteoPIdmteoPIEdesktopX~6 lote notesFtxt GhomeGmteoPIGnotesFtxt
La commande a retrouv notre chier notes.txt qui tait situ dans /home/mateo21. Essayons maintenant de retrouver ces vieilles photos d'Australie. . .
mteoPIdmteoPIEdesktopXGvrGlog6 lote ustrlie GhomeGmteoPIGphotosGustrlieIFjpg GhomeGmteoPIGphotosGustrliePFjpg GhomeGmteoPIGphotosGustrlieQFjpg
locate vous donne tous les chiers qui contiennent le mot australie dans leur nom.
Que ce soient des chiers ou des dossiers, elle ne fait pas la dirence. Elle vous donne la liste complte des chiers qu'elle a trouvs.
Il existe aussi la commande slocate qui est un peu plus rcente, mais on ne la retrouve pas sur toutes les distributions par dfaut. Vous pouvez toutefois l'installer rapidement avec un apt-get si vous ne l'avez pas. La commande slocate est identique locate, la dirence prs qu'elle vrie les droits des chiers avant de les lister. Avec slocate, un utilisateur ne pourra donc pas voir un nom de chier apparatre s'il n'a pas le droit de le lire, tandis qu'avec un locate le nom du chier serait apparu dans les rsultats quand mme.
FIND
La mise jour de la liste des chiers peut tre un peu longue, il faudra patienter. Une fois que c'est ni, ressayez de faire un locate, il devrait maintenant trouver votre chier. En rsum, locate est pratique car rapide et facile utiliser. Cependant, locate donne parfois trop de rsultats car elle recherche dans tous les rpertoires du disque dur, elle n'est donc pas trs prcise. De plus, les chiers qui viennent tout juste d'tre crs ne seront pas dcouverts, moins d'excuter updatedb. Quand locate ne sut pas, on a besoin d'une commande plus puissante. On sort l'artillerie lourde : find.
find
find est la commande de recherche par excellence pour retrouver des chiers, mais aussi
pour eectuer des oprations sur chacun des chiers trouvs. Elle est trs puissante, permet donc de faire beaucoup de choses, et par consquent. . . elle est un peu complexe. 249
CHAPITRE 16.
find
Contrairement locate, find ne va pas lire dans une base de donnes mais au contraire parcourir tout votre disque dur (gure 16.2). Cela peut tre trs long si vous avez plusieurs giga-octets de donnes !
FIND
Le -name "logo.png" est un paramtre qui demande de retrouver un chier qui s'appelle trs exactement logo.png. Voici le rsultat :
mteoPIdmteoPIEdesktopX~6 find Enme 4logoFpng4 GhomeGmteoPIGprojetGimgesGlogoFpng
Comme nous n'avons pas prcis o rechercher, find a cherch dans le rpertoire dans lequel nous nous trouvions et dans ses sous-rpertoires. Le ~ de l'invite de commandes signie que j'tais dans mon home, c'est--dire dans /home/mateo21/. Tous les sous-rpertoires ont t analyss.
Maintenant, si je suis dans mon home mais que je veux rechercher dans un autre rpertoire, il faudra prciser en premier paramtre le rpertoire dans lequel chercher. Par exemple, si je veux retrouver tous les chiers qui s'appellent syslog situs dans /var/log (et ses sous-rpertoires), je dois crire :
find GvrGlogG Enme 4syslog4
Essayons a !
mteoPIdmteoPIEdesktopX~6 find GvrGlogG Enme 4syslog4 GvrGlogGsyslog GvrGlogGinstllerGsyslog
Les paramtres correspondent ceux que je vous ai prsents un peu plus tt : 251
CHAPITRE 16.
o : dans /var/log (et ses sous-dossiers) ; quoi : le chier syslog. Il n'y a pas de paramtre que faire avec , donc par dfaut find choisit d'acher les chiers trouvs. Notez que, contrairement locate, find rcupre uniquement la liste des chiers qui s'appellent exactement comme demand. Ainsi, s'il existe un chier nomm syslog2, il ne sera pas list dans les rsultats. Pour qu'il le soit, il faut utiliser le joker : l'toile * ! Exemple :
mteoPIdmteoPIEdesktopX~6 find GvrGlogG Enme 4syslogB4 GvrGlogGsyslogFQFgz GvrGlogGsyslogFSFgz GvrGlogGsyslogFRFgz GvrGlogGsyslog GvrGlogGsyslogFTFgz GvrGlogGsyslogFPFgz GvrGlogGsyslogFIFgz GvrGlogGinstllerGsyslog GvrGlogGsyslogFH
Ici, nous avons ach tous les chiers qui commenaient par syslog . Si on avait voulu avoir la liste des chiers qui se terminent par syslog , on aurait crit "*syslog". De mme, si on avait voulu avoir la liste des chiers qui contiennent syslog , que ce soit au dbut, au milieu ou la n, on aurait crit "*syslog*". L'toile est donc un joker qui signie il peut y avoir n'importe quel caractre cet endroit .
Et si je veux rechercher sur tout le disque dur, et pas seulement dans un dossier ?
Facile, il sut d'indiquer le rpertoire racine /. Je vous rappelle que sous Linux, tous les dossiers sont situs dans un sous-niveau de /. C'est un petit peu l'quivalent du C: sous Windows.
find G Enme 4syslog4
La recherche depuis la racine prend beaucoup de temps si vous avez de nombreux chiers. De plus, si vous n'tes pas root, vous aurez de nombreux messages d'erreur vous indiquant que vous n'avez pas le droit d'aller dans certains rpertoires. En gnral, moins d'tre trs patient (ou dsespr), on ne fait pas de recherche depuis la racine.
252
FIND
Rappel : le tilde ~ signie rechercher dans mon home , en l'occurrence chez moi /home/mateo21/ .
Au lieu de se baser sur le nom, on se base ici sur la taille (-size). Le +10M indique que l'on recherche des chiers de plus de 10 Mo. On peut aussi utiliser k pour les Ko, G pour les Go, etc. Vous pouvez aussi utiliser un moins - la place du + pour obtenir par exemple les chiers de moins de 10 Mo. Et si vous enlevez le + , la commande cherchera des chiers de 10 Mo exactement (ni plus, ni moins).
J'ai combin ici une recherche par le nom avec une recherche par la date. Si je ne me souvenais mme plus de l'extension du chier, j'aurais d utiliser seulement -atime, mais a m'aurait probablement donn beaucoup de chiers (en fait, tous les chiers modis depuis 7 jours dans mon rpertoire personnel !). L encore, vous pouvez utiliser un + la place. . . ou mme enlever le signe pour rechercher un chier auquel on aurait accd il y a exactement 7 jours.
CHAPITRE 16.
-type d : pour rechercher uniquement des rpertoires (directories ) ; -type f : pour rechercher uniquement des chiers (les ). Par dfaut, find cherche des rpertoires ET des chiers. Ainsi, si vous avez un chier appel syslog et un rpertoire appel syslog, les deux rsultats seront achs. Pour obtenir uniquement les rpertoires qui s'appellent syslog (et non pas les chiers), tapez donc :
find GvrGlog Enme 4syslog4 Etype d
. . . est quivalent :
find ~ Enme 4BFjpg4 Eprint
-print signie acher les rsultats trouvs . Si le -print n'est pas crit, la commande comprend toute seule qu'elle doit acher la liste des chiers. On peut cependant remplacer ce -print par d'autres paramtres.
Ici, j'ache le nom du chier, un tiret et le nom du propritaire de ce chier. Le \n permet d'aller la ligne.
1. Qui rappellera certains le langage C.
254
FIND
Je vous conseille fortement de lire la doc', la section -printf (faites une recherche). Direction : man find ! Vous y trouverez tous les lments utilisables avec -printf, en plus du %p et du %u.
Soyez bien srs de ce que vous faites ! Il n'y aura pas de conrmation !
Et voil, toutes les images ont disparu.
CHAPITRE 16.
Si le fait que la commande ne vous demande pas de conrmation vous ennuie, vous pouvez utiliser -ok la place de -exec. Le principe est le mme, mais on vous demandera une conrmation pour chaque chier rencontr. Il faudra rpondre par y (yes ) ou n (no ) chaque fois.
En rsum
Pour rechercher un chier sur tout le disque, la commande locate est trs rapide mais ne trouvera pas les chiers qui viennent d'tre crs dans la journe. On peut mettre jour la liste des chiers qu'elle connat en appelant updatedb. find est une commande plus puissante mais plus lente qui va parcourir votre disque la recherche de vos chiers. Elle peut s'utiliser avec trois paramtres, dans l'ordre : o chercher, que chercher et que faire avec. On peut rechercher des chiers en fonction de leur nom (-name), de leur taille (-size), de leur date de dernier accs (-atime). . . Au lieu d'acher les chiers trouvs, on peut automatiquement les supprimer avec -delete ou excuter la commande de son choix sur chacun d'eux avec -exec.
256
Troisime partie
Contrler les processus et les ux de donnes
257
Chapitre
17
Dicult :
omme vous le savez dj, la plupart des commandes de Linux sont bases sur le modle du systme d'exploitation Unix. Ce sont les mmes. Certaines s'utilisent de la mme manire depuis les annes 60 ! Avantage pour les informaticiens : pas besoin de rapprendre utiliser les mmes commandes tous les trois mois. Mais la question que vous devez vous poser est la suivante : comment se fait-il que la plupart de ces commandes n'aient pas chang depuis si longtemps ? La rponse vient du fait qu'elles n'ont pas eu besoin de changer. En eet, la plupart des commandes que vous dcouvrez sont trs basiques : elles accomplissent une tche et le font bien, mais pas plus. Ce sont les briques de base du systme. Dans ce chapitre, nous allons dcouvrir une srie de commandes basiques qui permettent d'extraire, trier et ltrer des donnes dans des chiers. Vous utiliserez certaines d'entre elles (comme grep) presque tous les jours !
259
CHAPITRE 17.
grep
La commande grep est essentielle. De toutes celles prsentes dans ce chapitre, il s'agit probablement de la plus couramment utilise. Son rle est de rechercher un mot dans un chier et d'acher les lignes dans lesquelles ce mot a t trouv. L'avantage de cette commande est qu'elle peut tre utilise de manire trs simple ou plus complexe (mais plus prcise) selon les besoins en faisant appel aux expressions rgulires.
Les expressions rgulires constituent un moyen trs puissant de rechercher un texte. On les utilise non seulement dans la ligne de commandes Linux, mais aussi dans des diteurs de texte avancs et dans de nombreux langages de programmation tels que PHP. Vous trouverez d'ailleurs deux chapitres assez complets au sujet des expressions rgulires dans le livre Concevez votre site web avec PHP et MySQL que j'ai rdig 1 .
Nous allons commencer par utiliser grep de manire trs simple ; nous verrons ensuite comment faire des recherches plus pousses avec les expressions rgulires.
Le premier paramtre est le texte rechercher, le second est le nom du chier dans lequel ce texte doit tre recherch. Essayons par exemple de rechercher le mot alias dans notre chier de conguration .bashrc. Rendez-vous dans votre rpertoire personnel (en tapant cd) et lancez la commande suivante :
grep lis Fshr
Cette commande demande de rechercher le mot alias dans le chier .bashrc et ache toutes les lignes dans lesquelles le mot a t trouv. Rsultat :
6 grep lis Fshr
1. Vous pouvez aussi retrouver l'essentiel dans le tutoriel correspondant sur le Site du Zro (code web : 707921).
260
GREP
5 ~GFshlisesD insted of dding them here diretlyF 5if Ef ~GFshlises Y then 5 F ~GFshlises 5 enle olor support of ls nd lso dd hndy lises lis lsa9ls EEolorauto9 5lis dira9ls EEolorauto EEformtavertil9 5lis vdira9ls EEolorauto EEformtalong9 5 some more ls lises lis lla9ls Elerth9 5lis la9ls Ee9 5lis la9ls Egp9
Pas mal, n'est-ce pas ? Comme vous pouvez le voir, grep est davantage un outil de ltre qu'un outil de recherche. Son objectif est de vous acher uniquement les lignes qui contiennent le mot que vous avez demand. Notez qu'il n'est pas ncessaire de mettre des guillemets autour du mot trouver, sauf si vous recherchez une suite de plusieurs mots spars par des espaces, comme ceci :
grep 4ite du ro4 monfihier
-i
Par dfaut, grep tient compte de la casse : il fait la distinction entre les majuscules et les minuscules. Ainsi, si vous recherchez alias et qu'une ligne contient Alias , grep ne la renverra pas. Pour que grep renvoie toutes les lignes qui contiennent alias , peu importent les majuscules et les minuscules, utilisez l'option -i :
6 grep Ei lis Fshr 5 elis definitionsF 5 ~GFshlisesD insted of dding them here diretlyF 5if Ef ~GFshlises Y then 5 F ~GFshlises 5 enle olor support of ls nd lso dd hndy lises lis lsa9ls EEolorauto9 5lis dira9ls EEolorauto EEformtavertil9 5lis vdira9ls EEolorauto EEformtalong9 5 some more ls lises lis lla9ls Elerth9 5lis la9ls Ee9 5lis la9ls Egp9
On notera que la premire ligne renvoye (ici surligne) n'tait pas prsente tout l'heure car le mot Alias contenait une majuscule. Avec l'option -i on peut dsormais la voir. 261
CHAPITRE 17.
-n
-v
Si, au contraire, vous voulez connatre toutes les lignes qui ne contiennent pas un mot donn, utilisez -v :
6 grep Ev lis Fshr 5 ~GFshrX exeuted y sh@IA for nonElogin shellsF 5 see GusrGshreGdoGshGexmplesGstrtupEfiles @in the pkge shEdoA 5 for exmples 5 sf not running intertivelyD don9t do nything Ez 46I4 88 return 5 don9t put duplite lines in the historyF ee sh@IA for more options export rsgyxyvaignoredups 5 FFF nd ignore sme suessive entriesF export rsgyxyvaignoreoth 5 FFF @renvoie euoup de lignesD je ne mets ps tout iiA
Cette fois, on rcupre toutes les lignes du chier .bashrc qui ne contiennent pas le mot alias . 262
GREP -r
Si vous ne savez pas dans quel chier se trouve le texte que vous recherchez, vous pouvez sortir l'artillerie lourde : l'option -r (recursive ). Cette fois, il faudra indiquer en dernier paramtre le nom du rpertoire dans lequel la recherche doit tre faite (et non pas le nom d'un chier).
grep Er 4ite du ro4 odeG
. . . recherchera la chane Site du Zro dans tous les chiers du rpertoire code, y compris dans les sous-dossiers.
Notez que le / la n n'est pas obligatoire. Sans cela Linux comprendra tout de mme trs bien qu'il s'agit d'un rpertoire.
6 grep Er 4ite du ro4 odeG odeGintroFhtmlX xous vous souhitons l ienvenue sur le ite du ro 3 odeGtplGdefineFtplX ve ite du ro
Cette fois, le nom du chier dans lequel la chane a t trouve s'ache au dbut de la ligne.
noter qu'il existe aussi la commande rgrep qui est quivalente grep
-r.
CHAPITRE 17.
Caractre quelconque Dbut de ligne Fin de ligne Un des caractres entre les crochets L'lment prcdent est optionnel (peut tre prsent 0 ou 1 fois) L'lment prcdent peut tre prsent 0, 1 ou plusieurs fois L'lment prcdent doit tre prsent 1 ou plusieurs fois Ou Groupement d'expressions
expressions rgulires, je vous propose donc de jeter un il ces quelques lignes pour apprendre par l'exemple. Tout d'abord, il faut savoir qu'on doit utiliser l'option -E pour faire comprendre grep que l'on utilise une expression rgulire.
6 grep Ei elis Fshr 5 elis definitionsF
Notez que vous pouvez aussi utiliser la commande egrep qui quivaut crire grep -E.
C'est une expression rgulire trs simple. Elle demande de rechercher le mot Alias (avec un A majuscule). Si le mot est prsent dans une ligne, cette dernire est renvoye. Bon, jusque-l, rien de nouveau ; a fonctionnait comme a avant qu'on utilise les expressions rgulires. Essayons de pimenter cela en faisant prcder Alias d'un accent circonexe qui signie que le mot doit tre plac au dbut de la ligne :
6 grep Ei elis Fshr
Rsultat : grep ne renvoie rien. En eet, la ligne de tout l'heure commenait par un # et non pas par Alias . En revanche, on a un rsultat si on fait ceci : 264
SORT
Cette fois, la ligne commenait bien par alias . De mme, on aurait pu utiliser un $ la n pour demander ce que la ligne se termine par alias . Quelques autres exemples que vous pouvez tester :
grep Ei elis Fshr
. . . renvoie toutes les lignes qui contiennent un caractre alphabtique compris entre a et z ou entre A et Z . Je vous ai fait l une introduction trs rapide mais il y aurait beaucoup dire. Si vous voulez en savoir plus sur les expressions rgulires, vous trouverez dans mon livre PHP 2 ou sur le Site du Zro des explications plus compltes.
Comme vous pourrez le constater, les expressions rgulires fonctionnent aussi bien sans le -E. Pourquoi ? Normalement, cette option sert activer la gestion des expressions rgulires les plus complexes. Dans la pratique, le manuel nous dit que la version GNU de grep (celle que l'on utilise sous Linux) ne fait pas de dirence, que l'option soit prsente ou non. Les expressions rgulires sont toujours actives. En clair, vous aurez besoin du -E si un jour vous utilisez grep sur une autre machine de type Unix mais en attendant, vous pouvez trs bien vous en passer. Le -E a t conserv pour des raisons de compatibilit.
sort
La commande sort se rvle bien utile lorsqu'on a besoin de trier le contenu d'un chier. Pour nos exemples, je vous propose de crer un nouveau chier (avec nano par exemple) appel noms.txt et d'y placer le texte suivant :
2. Concevez votre site web avec PHP et MySQL (Livre du Zro)
265
CHAPITRE 17.
Liste de noms Code web : 707921 Ensuite, excutez la commande sort sur ce chier :
6 sort nomsFtxt elert prnois ten jonthn wrel ptrie tphne inent
Le contenu du chier est tri alphabtiquement et le rsultat est ach dans la console. Vous noterez que sort ne fait pas attention la casse (majuscules / minuscules).
-o
Le chier en lui-mme n'a pas t modi lorsque nous avons lanc la commande. Seul le rsultat tait ach dans la console. Vous pouvez faire en sorte que le chier soit modi en prcisant un nom de chier avec l'option -o :
sort Eo nomstriesFtxt nomsFtxt
266
SORT
inent tphne ptrie wrel jonthn ten prnois elert
-R
: trier alatoirement
Cette option permet de trier alatoirement les lignes d'un chier. C'est assez amusant et a peut se rvler utile dans certains cas :
6 sort E nomsFtxt ptrie prnois wrel jonthn ten elert inent tphne
-n
Le tri de nombres est un peu particulier. En eet, la commande sort ne distingue pas si les caractres sont des nombres et va donc par dfaut les trier par ordre alphabtique. Par consquent, le mot 129 prcdera 42 alors que a devrait tre l'inverse ! Prenons un exemple. Crez un nouveau chier nombres.txt et placez-y les nombres suivants :
QT IT RP IPW PU QTR
Liste de nombres Code web : 897818 Triez-les comme vous avez appris le faire : 267
CHAPITRE 17.
Alphabtiquement, ces nombres sont bien tris. Tout ce qui commence par 1 est en premier, puis vient ce qui commence par 2 et ainsi de suite. Bien sr, quand on veut trier des nombres, c'est n'importe quoi. C'est l que l'option -n intervient. Elle permet de trier en considrant le texte comme des nombres. Cette fois, le nombre 42 sera bien plac avant 129 !
6 sort En nomresFtxt IT PU QT RP IPW QTR
Magique. ;-)
wc
La commande wc signie word count. C'est donc a priori un compteur de mots mais en fait, on lui trouve plusieurs autres utilits : compter le nombre de lignes (trs frquent) et compter le nombre de caractres. Comme les prcdentes, la commande wc travaille sur un chier. Sans paramtre, les rsultats renvoys par wc sont un peu obscurs. Voyez plutt :
6 w nomsFtxt V V TR nomsFtxt
Ces trois nombres signient, dans l'ordre : 1. le nombre de lignes. 2. le nombre de mots. 268
WC
Dans le cas de notre chier noms.txt, il est normal d'avoir autant de lignes que de mots car nous avions mis un seul mot par ligne.
-l
-w
-c
-m
Ah, voil une information qui ne nous a pas t donne lorsque nous avons lanc la commande wc sans paramtre. L'option -m renvoie le nombre de caractres :
6 w Em nomsFtxt TP nomsFtxt
Comme vous pouvez le voir, le nombre de caractres est dirent du nombre d'octets. 269
CHAPITRE 17.
uniq
Parfois, certains chiers contiennent des lignes en double et on aimerait pouvoir les dtecter ou les supprimer. La commande uniq est toute indique pour cela. Nous devons travailler sur un chier tri. En eet, la commande uniq ne repre que les lignes successives qui sont identiques. Je vous propose de crer un chier doublons.txt contenant les noms suivants :
elert prnois prnois prnois ten jonthn wrel wrel ptrie tphne inent
Liste avec doublons Code web : 719552 Il y a des noms en double (et mme en triple) dans ce chier. Appliquons un petit coup de uniq l-dessus pour voir ce qu'il en reste :
6 uniq doulonsFtxt elert prnois ten jonthn wrel ptrie tphne inent
La liste de noms sans les doublons s'ache alors dans la console ! Vous pouvez demander ce que le rsultat sans doublons soit crit dans un autre chier plutt qu'ach dans la console :
uniq doulonsFtxt snsdoulonsFtxt
CUT -c
Avec -c, la commande uniq vous ache le nombre de fois que la ligne est prsente dans le chier :
6 uniq E doulonsFtxt I elert Q prnois I ten I jonthn P wrel I ptrie I tphne I inent
On sait ainsi qu'il y a trois fois Franois , une fois Jean , deux fois Marcel , etc.
-d
Comme seuls Franois et Marcel avaient des doublons, on les voit ici s'acher dans la console.
Comme pour les autres commandes prsentes dans ce chapitre, je ne vous ai pas fait la liste de toutes les options disponibles. J'ai choisi de vous prsenter celles qui me paraissaient les plus intressantes ou les plus utiles, mais c'est tout fait subjectif. Ayez le rexe d'aller regarder le manuel (man uniq par exemple) pour connatre la liste exhaustive des options de la commande.
cut
Vous avez dj coup du texte dans un diteur de texte, non ? La commande cut vous propose de faire cela au sein d'un chier an de conserver uniquement une partie de chaque ligne. 271
CHAPITRE 17.
a quelques soucis avec les mots contenant des accents. Comme vous pouvez le voir, certains mots ici coups ont quatre lettres (comme prvu) alors que d'autres en ont trois. Ceci est d l'encodage des caractres, aux accents. La commande cut se base sur le nombre d'octets, et comme nous l'avons vu plus tt, celui-ci n'est pas forcment gal au nombre de caractres. l'heure actuelle on ne peut rien y faire, c'est la commande cut qui devra tre mise jour par les programmeurs.
cut
Comme vous pouvez le voir, si on ne met pas de chire au dbut, cut comprend que vous voulez parler du premier caractre. De mme, pour conserver du 3e au dernier caractre :
6 ut E QE nomsFtxt nois rel
272
CUT
ert n phne trie nent nthn
L encore, pas besoin de donner le numro du dernier caractre 3 , la commande cut comprend comme une grande qu'elle doit couper jusqu' la n.
Notes en CSV Code web : 172591 Comme le nom CSV l'indique, les virgules servent sparer les colonnes. Ces dernires contiennent, dans l'ordre : le prnom ; la note ; un commentaire. C'est un exemple tout fait ctif, bien entendu. ;-) Crez, avec le texte que je viens de vous donner, un nouveau chier que vous appellerez par exemple notes.csv.
3. Ce serait un peu ennuyeux de compter chaque fois, avouez. 4. Comma Separated Values. Ce sont des chiers dont les valeurs sont spares par des virgules. Notez qu'Excel utilise plutt le point-virgule comme sparateur, mais le principe reste le mme.
273
CHAPITRE 17.
Imaginons que nous souhaitions extraire de ce chier la liste des prnoms. Comment nous y prendrions-nous ? On ne peut pas utiliser la technique qu'on vient d'apprendre car les prnoms ne font pas tous la mme longueur. Nous allons donc nous servir du fait que nous savons que la virgule spare les dirents champs dans ce chier. Vous allez avoir besoin d'utiliser deux paramtres : -d : indique quel est le dlimiteur dans le chier ; -f : indique le numro du ou des champs couper. Dans notre cas, le dlimiteur qui spare les champs est la virgule. Le numro du champ couper est 1 (c'est le premier). Testez donc ceci :
6 ut Ed D Ef I notesFsv prie inent ophie wlnie gorentin elert fenot
C'est pas beau, a ? :-) Aprs le -d, nous avons indiqu quel tait le dlimiteur ( savoir la virgule , ). Aprs le -f, nous avons indiqu le numro du champ conserver (le premier). Si nous voulons juste les commentaires :
6 ut Ed D Ef Q notesFsv ixellent trvil xul omme d9h in nette progression ellez presque l moyenne 3 s ml mis peut mieux fire oujours prfit in grve hute
274
CUT
gorentinDs ml mis peut mieux fire elertDoujours prfit fenotDin grve hute
De mme, il est possible de conserver toute une srie de champs avec le tiret comme tout l'heure : cut -d , -f 2-4 notes.csv a pour eet de conserver les champs nos 2, 3 et 4. D'autre part, cut -d , -f 3- notes.csv conserve les champs du no 3 jusqu' la n.
Vous tes bien obligs d'admettre que, quand on sait bien s'en servir, la console de Linux peut vous permettre d'eectuer des oprations vraiment puissantes que vous ne pensiez mme pas pouvoir faire aussi simplement jusqu' prsent. ;-)
En rsum
grep est une commande couramment utilise pour rechercher un mot dans un chier. On peut utiliser des expressions rgulires, un systme complexe mais puissant, pour eectuer des recherches prcises. On fait dans ce cas appel la commande egrep. sort trie des lignes de texte par ordre alphabtique. Le paramtre -n permet de trier par ordre numrique. wc compte le nombre de lignes, de mots et d'octets dans un chier. uniq supprime les doublons d'un chier. cut coupe une partie d'un chier.
275
CHAPITRE 17.
276
Chapitre
18
Dicult :
ous devriez maintenant avoir l'habitude d'un certain nombre de commandes que propose la console de Linux. Le fonctionnement est toujours le mme :
1. vous tapez la commande (par exemple ls) ; 2. le rsultat s'ache dans la console.
Ce que vous ne savez pas encore, c'est qu'il est possible de rediriger ce rsultat. Au lieu que celui-ci s'ache dans la console, vous allez pouvoir l'envoyer ailleurs : dans un chier ou en entre d'une autre commande pour eectuer des chanes de commandes . Grce ce chapitre sur les ux de redirection, vous allez beaucoup gagner en matrise de la ligne de commandes !
277
CHAPITRE 18.
Dans ce chapitre, nous allons dcouvrir qu'il est possible de rediriger le rsultat d'une commande ailleurs que dans la console. O ? Dans un chier, ou en entre d'une autre commande pour chaner des commandes . Ainsi, le rsultat d'une commande peut en dclencher une autre ! Comment ? l'aide de petits symboles spciaux, appels ux de redirection, que vous allez dcouvrir dans ce chapitre. Le principe peut tre rsum dans le schma de la gure 18.1.
Les ux de redirection constituent une composante essentielle de la console sous Linux et ce, depuis l'poque d'Unix. Ils vont trs certainement changer votre faon de voir comment la console fonctionne et dmultiplier votre contrle sur les commandes que vous lancez. C'est dire si ce chapitre est important !
Je vais donc d'abord vous demander d'tre encore plus attentifs que d'habitude. Non pas que le chapitre soit rellement compliqu , mais il doit bien tre compris pour que vous puissiez suivre le reste du livre convenablement. Au pire des cas, vous pourrez toujours revenir lire ce chapitre si vous avez un trou de mmoire sur les notions que vous y avez apprises. ;-)
>
La manipulation la plus simple que nous allons voir va nous permettre d'crire le rsultat d'une commande dans un chier, au lieu de l'acher btement dans la console. 278
>
ET
>>
Prparatifs
Prenons une commande au hasard. Vous vous souvenez de cut, que nous avons appris dans le chapitre prcdent ? Nous avions travaill sur un petit chier de type CSV que les tableurs peuvent gnrer. Ce sont les notes des lves d'une classe un contrle :
prieDIV G PHDixellent trvil wthieuDQ G PHDxul omme d9h9 ophieDIR G PHDin nette progression wlnieDW G PHDellez presque l moyenne 3 gorentinDII G PHDs ml mis peut mieux fire elertDPH G PHDoujours prfit fenotDS G PHDin grve hute
Si vous ne l'aviez pas dj fait dans le chapitre prcdent, je vous recommande d'enregistrer ce chier dans un diteur de texte (comme Nano) en rcuprant le contenu ci-dessus l'aide du code web. Enregistrez le tout sous le nom notes.csv.
La commande cut nous avait permis de couper une partie du chier et d'acher le rsultat dans la console. Par exemple, nous avions demand cut de prendre tout ce qui se trouvait avant la premire virgule an d'avoir la liste des noms de tous les lves prsents ce contrle :
6 ut Ed D Ef I notesFsv prie inent ophie wlnie gorentin elert fenot
Ce rsultat s'est ach dans la console. C'est ce que font toutes les commandes par dfaut. . . moins que l'on utilise un ux de redirection !
CHAPITRE 18.
le petit symbole magique > (appel chevron) que je vous laisse trouver sur votre clavier 1 . Ce symbole permet de rediriger le rsultat de la commande dans le chier de votre choix. Essayez par exemple de taper ceci :
ut Ed D Ef I notesFsv b elevesFtxt
Regardez la n de la commande. J'y ai rajout la petite che > qui redirige la sortie de la commande dans un chier. Normalement, si vous excutez cette commande, rien ne s'achera dans la console. Tout aura t redirig dans un chier appel eleves.txt qui vient d'tre cr pour l'occasion dans le dossier dans lequel vous vous trouviez.
Je le rappelle au cas o : sous Linux, on se moque pas mal de l'extension des chiers. J'aurais trs bien pu crer un chier sans extension appel eleves. Ici j'ai rajout un .txt pour ne pas drouter ceux qui viennent de Windows, mais il faudra vous habituer travailler avec des noms de chiers parfois sans extension.
Faites un petit ls (ou ls -l, comme vous prfrez) pour voir si le chier est bien prsent dans le dossier :
6 ls El totl PH ErwErEErEE I mteoPI mteoPI WI PHHVEHREIW IWXQT doulonsFtxt ErwErEErEE I mteoPI mteoPI ST PHHVEHWEPT IPXHI elevesFtxt ErwErEErEE I mteoPI mteoPI QS PHHVEHREIW IUXHT fihiertrieFtxt ErwErEErEE I mteoPI mteoPI PH PHHVEHREIW IWXHQ nomresFtxt ErwErEErEE I mteoPI mteoPI PSQ PHHVEHWEPT IPXHI notesFsv
Comme vous pouvez le voir, un chier vient bien d'tre cr ! Vous pouvez l'ouvrir avec Nano ou encore l'acher dans la console avec la commande cat (pour acher tout d'un coup s'il est court) ou less (pour acher page par page s'il est long).
Attention : si le chier existait dj il sera cras sans demande de conrmation ! Parfois, vous ne voulez ni voir le rsultat d'une commande ni le stocker dans un chier. Dans ce cas, l'astuce consiste rediriger le rsultat dans /dev/null. C'est un peu le trou noir de Linux : tout ce qui va l-dedans disparat immdiatement. Par exemple : commande_bavarde > /dev/null
1. Ceux qui font du HTML le connaissent bien. ;-)
280
>
ET
>>
>>
Le double chevron >> sert lui aussi rediriger le rsultat dans un chier, mais cette fois la n de ce chier. Avantage : vous ne risquez pas d'craser le chier s'il existe dj. Si le chier n'existe pas, il sera cr automatiquement. Normalement, vous devriez avoir cr un chier eleves.txt lors des manipulations prcdentes. Si vous faites :
ut Ed D Ef I notesFsv bb elevesFtxt
. . . les noms seront ajouts la n du chier, sans craser le rsultat prcdent. Bon, du coup, on a des noms en double maintenant :
6 t elevesFtxt prie wthieu ophie wlnie gorentin elert fenot prie wthieu ophie wlnie gorentin elert fenot
Heureusement, vous connaissez les commandes sort et uniq qui peuvent vous permettre de faire un peu de mnage l-dedans. Je vous laisse supprimer les doublons. N'oubliez pas qu'il faut que le chier soit tri pour que la commande uniq fonctionne !
281
CHAPITRE 18.
Grce a, si j'ai un doute sur ce qui a pu se passer lors de l'excution d'une commande, je n'ai qu' consulter le chier resultats.log.
Rsum
Nous venons de dcouvrir deux ux de redirection dans des chiers : > : redirige dans un chier et l'crase s'il existe dj ; >> : redirige la n d'un chier et le cre s'il n'existe pas. Le schma de la gure 18.2 rcapitule ce que nous venons de voir.
2>, 2>>
Allons un peu plus loin. Il faut savoir que toutes les commandes produisent deux ux de donnes dirents, comme le montre la gure 18.3 : la sortie standard : pour tous les messages (sauf les erreurs) ; la sortie d'erreurs : pour toutes les erreurs. Prenons un exemple concret pour voir comment a se passe. Supposons que vous fassiez un cat du chier notes.csv pour acher son contenu. Il y a deux possibilits : si tout va bien, le rsultat (le contenu du chier) s'ache sur la sortie standard ; s'il y a une erreur, celle-ci s'ache dans la sortie d'erreurs. Par dfaut, tout s'ache dans la console : la sortie standard comme la sortie d'erreurs. Cela explique pourquoi vous ne faisiez pas la dirence entre ces deux sorties jusqu'ici : elles avaient l'air identiques. Tout l'heure, nous avons vu comment rediriger la sortie standard dans un chier. Toutefois, les erreurs continuent d'tre aches dans la console. Faites le test :
ut Ed D Ef I fihierinexistntFsv b elevesFtxt utX fihierinexistntFsvX euun fihier ou rpertoire de e type
282
2>, 2>>
ET
2>&1
Il y a deux redirections ici : > eleves.txt : redirige le rsultat de la commande (sauf les erreurs) dans le chier eleves.txt. C'est la sortie standard ; 2> erreurs.log : redirige les erreurs ventuelles dans le chier erreurs.log. C'est la sortie d'erreurs. Vous pouvez vrier : si fichier_inexistant.csv n'a pas t trouv, l'erreur aura t inscrite dans le chier erreurs.log au lieu d'tre ache dans la console.
2>>
CHAPITRE 18.
Il faut utiliser le code suivant : 2>&1. Cela a pour eet de rediriger toute la sortie d'erreurs dans la sortie standard. Traduction pour l'ordinateur : envoie les erreurs au mme endroit que le reste . Essayez donc ceci :
ut Ed D Ef I fihierinexistntFsv b elevesFtxt Pb8I
Tout ira dsormais dans eleves.txt : le rsultat (si cela a fonctionn), de mme que les erreurs (s'il y a eu un problme). Petite subtilit : je vous ai dit tout l'heure qu'il tait possible de faire 2>> pour rediriger les erreurs la n d'un chier d'erreurs. Toutefois, il n'est pas possible d'crire 2>>&1. Essayez, a ne marchera pas. En fait, le symbole 2>&1 va envoyer les erreurs dans le mme chier et de la mme faon que la sortie standard. Donc, si vous crivez :
ut Ed D Ef I fihierinexistntFsv bb elevesFtxt Pb8I
. . . les erreurs seront ajoutes la n du chier eleves.txt comme le reste des messages.
Rsum
Nous avons dcouvert trois symboles : 2> : redirige les erreurs dans un chier (s'il existe dj, il sera cras) ; 2>> : redirige les erreurs la n d'un chier (s'il n'existe pas, il sera cr) ; 2>&1 : redirige les erreurs au mme endroit et de la mme faon que la sortie standard. Le tout est illustr sur la gure 18.4.
<
ET
<<
J'ai volontairement omis de parler sur ce schma de >> et de 2>> an de ne pas le surcharger, mais le principe est le mme sauf qu'on ajoute la n d'un chier au lieu de l'craser.
<
Pour le moment, nous avons redirig uniquement la sortie des commandes. Nous avons dcid o envoyer les messages issus de ces commandes. Maintenant, je vous propose de faire un peu l'inverse, c'est--dire de dcider d'o vient l'entre d'une commande. Jusqu'alors, l'entre venait des paramtres de la commande. . . mais on peut faire en sorte qu'elle vienne d'un chier ou d'une saisie au clavier ! Regardez l'illustration de la gure 18.5.
Le chevron ouvrant < ( ne pas confondre avec le chevron fermant que nous avons utilis tout l'heure) permet d'indiquer d'o vient l'entre qu'on envoie la commande. On va prendre un exemple tout bte : la commande cat.
t ` notesFsv
285
CHAPITRE 18.
Il n'y a rien d'extraordinaire. On ne faisait pas pareil avant en crivant juste cat notes.csv par hasard ?
Si. crire cat < notes.csv est strictement identique au fait d'crire cat notes.csv. . . du moins en apparence. Le rsultat produit est le mme, mais ce qui se passe derrire est trs dirent. Si vous crivez cat notes.csv, la commande cat reoit en entre le nom du chier notes.csv qu'elle doit ensuite se charger d'ouvrir pour acher son contenu. Si vous crivez cat < notes.csv, la commande cat reoit le contenu de notes.csv qu'elle se contente simplement d'acher dans la console. C'est le shell (le programme qui gre la console) qui se charge d'envoyer le contenu de notes.csv la commande cat. Bref, ce sont deux faons de faire la mme chose mais de manire trs dirente. Pour le moment, je n'ai pas d'exemple plus intressant vous proposer ce sujet, mais retenez cette possibilit car vous nirez par en avoir besoin, faites-moi conance. ;-)
<<
Le double chevron ouvrant << fait quelque chose d'assez dirent : il vous permet d'envoyer un contenu une commande avec votre clavier. Cela peut s'avrer trs utile. Je vous propose un exemple concret pour bien voir ce que a permet de faire en pratique. Essayez de taper ceci :
sort En `` psx
Comme sort -n sert trier des nombres, on va justement crire des nombres, un par ligne (en appuyant sur la touche Entre chaque fois).
6 b b b b sort En `` psx IQ IQP IH IQI
<
ET
<<
Lorsque vous avez ni, tapez FIN pour arrter la saisie. Tout le texte que vous avez crit est alors envoy la commande (ici sort) qui traite cela en entre. Et, comme vous pouvez vous en douter, la commande sort nous trie nos nombres !
6 sort En `` psx b IQ b IQP b IH b IQI b QR b VU b TT b TV b TS b psx IH IQ QR TS TT TV VU IQI IQP
Sympa, non ? Cela vous vite d'avoir crer un chier si vous n'en avez pas besoin. Vous pouvez faire la mme chose avec une autre commande, comme par exemple wc pour compter le nombre de mots ou de caractres.
6 w Em `` psx b gomien de rtres dns ette phrse c b psx RP
287
CHAPITRE 18.
Ce qui compte, c'est que vous dnissiez un mot-cl qui servira indiquer la n de la saisie. Notez par ailleurs que rien ne vous oblige crire ce mot en majuscules.
Rsum
Nous pouvons donc alimenter des commandes de deux manires direntes, comme le montre la gure 18.6 : < : envoie le contenu d'un chier une commande ; << : passe la console en mode saisie au clavier, ligne par ligne. Toutes ces lignes seront envoyes la commande lorsque le mot-cl de n aura t crit.
Les nombres saisis au clavier seront envoys nombres_tries.txt, de mme que les erreurs ventuelles. H, mine de rien, on commence rdiger l des commandes assez complexes ! Mais vous allez voir, on peut faire encore mieux.
Passons maintenant au symbole le plus intressant que vous utiliserez le plus souvent : le pipe | (prononcez pape , comme un bon Anglais). Son but ? Chaner des commandes. 288
Le pipe | n'est pas un symbole qu'on a l'habitude d'crire. Pourtant, il y en a forcment un sur votre clavier (parfois reprsent sous la forme d'une ligne verticale en pointills). Sur un clavier AZERTY franais par exemple, vous pouvez l'crire en combinant les touches Alt Gr + 6 et sur un clavier belge, Alt Gr + 1. Sur un clavier Mac, c'est Alt + Shift + L
La thorie
Chaner des commandes ? Cela signie connecter la sortie d'une commande l'entre d'une autre commande (comme le montre la gure 18.7).
disais que chaque commande Unix avait un et un seul rle, mais qu'elle le remplissait bien. Parfois, l'utilit de certaines commandes seules peut paratre
La pratique
Voyons quelques cas concrets (on pourrait trouver une innit d'exemples).
289
CHAPITRE 18.
Avec cut, on peut rcuprer les noms. Avec sort, on peut les trier par ordre alphabtique. Pourquoi ne pas connecter cut sort pour avoir la liste des noms tris ?
6 ut Ed D Ef I notesFsv | sort elert fenot gorentin prie wthieu wlnie ophie
Le pipe eectue la connexion entre la sortie de cut (des noms dans le dsordre) et l'entre de sort, comme l'illustre la gure 18.8.
Deux problmes : cette liste est parfois trs longue et n'est pas trie. 290
Un problme la fois. Tout d'abord, on aimerait par exemple avoir cette mme liste dans l'ordre dcroissant de taille des rpertoires pour reprer plus facilement les plus gros d'entre eux qui prennent de la place sur notre disque. Pour avoir cette liste du plus grand au plus petit, il nous sut d'crire :
du | sort Enr
On envoie tout le contenu de du sort qui se charge de trier les nombres au dbut de chacune des lignes.
6 du | sort Enr FFF R R R R FGFevolutionGmemosGonfig FGFevolutionGlendrGonfig FGFevolutionGhe FGin
Problme : comme les plus gros rpertoires ont t achs en premier, et que j'ai beaucoup de sous-rpertoires, je dois remonter trs haut dans la console pour retrouver les plus gros d'entre eux. Que diriez-vous de connecter cette sortie head ? Cette commande permet de ltrer uniquement les premires lignes qu'elle reoit, nous l'avons dj tudie dans un chapitre prcdent.
6 du | sort Enr | hed IPHWPH F SWVTV FGFiesRlinux RQIHV FGFiesRlinuxGieT RIQTH FGFiesRlinuxGieTGdrive RIPRV FGFiesRlinuxGieTGdriveGwindows RHIRH FGhesktop QRSWP FGFiesRlinuxGieTGdriveGwindowsGsystemQP ITUPV FGFiesRlinuxGdownlods IQIPV FGFmozill IQIPR FGFmozillGfirefox
Vous pouvez paramtrer le nombre de rsultats achs avec l'option -n de head. Si vous avez oubli comment l'utiliser, retournez lire le cours sur head, page 162 ou consultez le manuel. Si vous voulez naviguer travers tous les rsultats, vous pouvez connecter la sortie less. Cette commande permet d'acher des rsultats page par page ; a nous est justement utile dans le cas prsent o nous avons beaucoup de rsultats ! 291
CHAPITRE 18.
Essayez ! Vous allez vous retrouver avec un achage de less, page par page.
IPHWPH F SWVTV FGFiesRlinux RQIHV FGFiesRlinuxGieT RIQTH FGFiesRlinuxGieTGdrive RIPRV FGFiesRlinuxGieTGdriveGwindows RHIRH FGhesktop QRSWP FGFiesRlinuxGieTGdriveGwindowsGsystemQP ITUPV FGFiesRlinuxGdownlods IQIPV FGFmozill IQIPR FGFmozillGfirefox IQIIP FGFmozillGfirefoxGvSpRSSdFdefult IPTHR FGFiesRlinuxGdownlodsGieT IIVHV FGFiesRlinuxGdownlodsGieTGp SVRV FGFmozillGfirefoxGvSpRSSdFdefultGghe QTST FGFiesRlinuxGieTGdriveGwindowsGprofiles QTIT FGFiesRlinuxGieTGdriveGwindowsGprofilesGmteoPI QRWT FGFiesRlinuxGieTGdriveGwindowsGprofilesGmteoPIGvol ettings QRIT FGFiesRlinuxGieTGdriveGwindowsGprofilesGmteoPIG vol ettingsGemporry snternet piles QRHV FGFiesRlinuxGieTGdriveGwindowsGprofilesGmteoPIG vol ettingsGemporry snternet pilesGgontentFsiS PPPH FGFiesRlinuxGieTGdriveGwindowsGfonts PHIP FGiesRlinuxEPFWWFHFI X
Vous pouvez maintenant voir les premiers chiers (les plus gros) et descendre progressivement vers les chiers plus petits, page par page avec la touche Espace ou ligne par ligne, avec la touche Entre (ou les ches du clavier). Exercice : peut-tre avez-vous toujours trop de rpertoires sous les yeux et que vous vous intressez seulement certains d'entre eux. Pourquoi ne pas ltrer les rsultats avec grep, pour acher uniquement la taille des rpertoires lis . . . Firefox par exemple ?
GvrGlogGinstllerGsyslogXepr T ISXIRXRQ uuntu xetworkwngerX `deugb IPHURWRVVQFHHRVVV GvrGlogGinstllerGsyslogXepr T ISXPQXPU uuntu pythonX logEoutput
Heureusement, le nom du chier et le contenu de la ligne sont spars par un deuxpoints. On connat cut, qui permet de rcuprer uniquement une partie de la ligne. Il nous permettrait de conserver uniquement le nom du chier. Problme : si le mme mot a t trouv plusieurs fois dans un chier, le chier apparatra en double ! Pour supprimer les doublons, on peut utiliser uniq, condition d'avoir bien tri les lignes avec sort auparavant. Alors, vous avez une petite ide de la ligne qu'il va falloir crire ? Je vous propose de rechercher les chiers qui contiennent le mot log dans le dossier /var/log. Notez qu'il faudra passer root avec sudo pour avoir accs tout le contenu de ce rpertoire. Voici la commande que je vous propose d'utiliser :
sudo grep log Esr GvrGlog | ut Ed X Ef I | sort | uniq
Que fait cette commande ? 1. Elle liste tous les chiers contenant le mot log dans /var/log (-I permettant d'exclure les chiers binaires). 2. Elle extrait de ce rsultat uniquement les noms des chiers. 3. Elle trie ces noms de chiers. 4. Elle supprime les doublons. Et voil le rsultat !
6 sudo grep log Esr GvrGlog | ut Ed X Ef I | sort | uniq GvrGlogGpid GvrGlogGuthFlog GvrGlogGoot GvrGlogGootstrpFlog GvrGlogGdistEupgrdeGptEtermFlog GvrGlogGdmesg GvrGlogGdmesgFH GvrGlogGgdmG GvrGlogGinstllerGprtmn GvrGlogGinstllerGsyslog GvrGlogGkernFlogFH GvrGlogGmessges GvrGlogGmessgesFH GvrGlogGsyslog GvrGlogGsyslogFH GvrGlogGudev
293
CHAPITRE 18.
Rsum
Le rsum est simple, et c'est dans sa simplicit qu'il tire toute sa beaut et sa puissance 2 , comme l'illustre la gure 18.9.
Les espaces avant et aprs le pipe ne sont en gnral pas obligatoires, mais je prfre les mettre ici pour une meilleure lisibilit.
En rsum
Au lieu d'acher le rsultat d'une commande dans une console, il est possible de l'enregistrer dans un chier. Il sut d'ajouter le symbole > suivi du nom du chier la n de la commande. Par exemple ls > liste_fichiers.txt enregistre la liste des chiers dans un chier plutt que de l'acher en console. Le symbole >> enregistre la n du chier au lieu de l'craser s'il existe dj. Les symboles 2> et 2>> permettent de rediriger seulement les erreurs dans un chier. Quant 2>&1 il redirige les erreurs dans le mme chier que les messages normaux. < permet de lire des donnes depuis un chier et de les envoyer une commande, tandis que << lit les donnes depuis le clavier. Le symbole | combine des commandes : les donnes de la commande sa gauche sont envoyes la commande sa droite. Ainsi, du | sort -nr rcupre la liste des chiers avec leur taille et l'envoie sort pour qu'il la trie.
294
Chapitre
19
Dicult :
omme tous les OS actuels, Linux est un systme multi-tches : il est capable de grer plusieurs programmes tournant en mme temps. Mieux encore, Linux est un systme multi-utilisateurs : plusieurs personnes peuvent utiliser la mme machine en mme temps (en s'y connectant via Internet). Tous ces programmes et ces personnes qui sont sur votre PC peuvent vite donner le tournis. Parfois, l'ordinateur peut se retrouver surcharg cause d'un programme. Qui a lanc ce programme ? Depuis quand ? Comment arrter un programme qui ne rpond plus ? Sous Windows, vous avez probablement entendu parler de la commande magique Ctrl + Alt + Suppr qui peut parfois vous sortir de bien des situations embarrassantes. Sous Linux, on utilise d'autres outils et d'autres techniques que vous allez apprendre connatre ici.
295
CHAPITRE 19.
Nous allons apprendre dans ce chapitre utiliser une srie de commandes qui nous permettront de savoir ce qui se passe actuellement dans notre ordinateur. La premire commande que je veux vous faire dcouvrir est trs courte et facile retenir : c'est w (comme la lettre, oui, oui). C'est la premire commande que je tape en gnral quand je me connecte un serveur surcharg et que je veux essayer de comprendre ce qui se passe. Cela me permet de voir d'un seul coup d'il si la machine est vraiment surcharge (et si oui, quel point) et si quelqu'un d'autre est en train d'intervenir sur la machine.
Si vous utilisez Linux sur votre ordinateur personnel, tranquillement chez vous, vous tes seuls l'utiliser en ce moment. Pour que d'autres personnes puissent se connecter votre ordinateur via Internet, il faut avoir congur Linux pour a. Nous verrons comment faire cela plus tard. On en a principalement besoin sur les serveurs.
Essayons d'utiliser w pour voir comment a marche ; n'ayez pas peur, c'est sans danger :
6 w ITXSHXQH up VXSHD P usersD lod vergeX HDHVD HDQRD HDQI i pyw vyqsxd shvi tg g re mteoPI XH E IWeprHV cxdmc QXQVm IFIVs GusrGinGgnomeE mteoPI ptsGH XHFH ITXRW HFHHs HFQQs HFHQs w
Bon : premire vue, c'est court mais dense, a n'a pas l'air trs clair. Pourtant, cette commande nous donne un condens d'informations trs utiles que je vais vous prsenter dans l'ordre, de gauche droite et de haut en bas.
La commande date permet en outre de modier la date enregistre dans l'ordinateur. C'est un peu particulier et pas trs intressant, nous ne verrons donc pas comment le faire ici 1 .
1. Mais il vous sut de lire le manuel si vous en avez vraiment besoin.
296
Notre serveur est en fonctionnement depuis 211 jours. Il n'a pas eu besoin d'tre redmarr depuis. Cela tmoigne notamment de la robustesse de Linux et de sa capacit tenir le coup pendant trs longtemps.
CHAPITRE 19.
C'est un peu compliqu. Si vous voulez vraiment savoir, la doc nous dit qu'il s'agit du nombre moyen de processus (programmes) en train de tourner et qui rclament l'utilisation du processeur. Cela veut dire que, depuis une minute, il y a en moyenne 0,33 processus qui rclament le processeur. Votre processeur est donc actif 33 % du temps. Mais ce nombre dpend du nombre de processeurs de votre ordinateur. Un ordinateur dual core ne sera compltement charg que lorsque la valeur aura atteint 2. Pour un quad core (4 curs de processeur), la valeur maximale avant surcharge sera de 4. Bref, rien ne vous oblige savoir ce que ce nombre signie. Vous avez juste besoin de savoir que, lorsqu'il dpasse 1 (si vous avez un processeur), 2 ou 4, alors votre ordinateur est surcharg. J'ai dj vu des machines avec une charge de 60, et mme plus ! Quand la charge est trs leve pendant une longue priode, c'est qu'il y a clairement un problme. Il y a trop de programmes qui rclament le processeur et quelque chose ne va pas dans l'ordinateur. Celui-ci aura du mal rpondre en cas de forte charge. Notez que vous pouvez obtenir un graphique de l'volution de la charge en console via la commande tload. Le graphe volue au fur et mesure du temps, il faut patienter un petit peu avant d'avoir quelque chose, comme l'illustre la gure 19.1.
PS
&
TOP
pyw E XHFH
vyqsxd shvi tg g re IWeprHV cxdmc QXQVm IFIVs GusrGinGgnome ITXRW HFHHs HFQQs HFHQs w
L, j'tais sur mon ordinateur personnel sous Ubuntu. Je ne l'ai pas congur pour qu'on puisse s'y connecter depuis Internet (comme vous, certainement), ce qui explique pourquoi je suis seul. Certes, j'apparais deux fois. Nous allons comprendre pourquoi lorsque nous aurons appris lire le tableau. Il n'est pas ncessaire de dcrire chacune des colonnes. Sachez qu'en gros vous avez : USER : le nom de l'utilisateur (son login) ; TTY : le nom de la console dans laquelle se trouve l'utilisateur. Souvenez-vous que sous Linux il y a en gnral six consoles (tty1 tty6) et qu'en plus de a, on peut en ouvrir une innit grce aux consoles graphiques (leur nom commence par pts, en gnral), comme le propose le programme Terminal sous Gnome ou Konsole sous KDE ; FROM : c'est l'adresse IP (ou le nom d'hte) depuis laquelle il se connecte. Ici, comme je me suis connect en local (sur ma propre machine, sans passer par Internet), il n'y a pas vraiment d'IP ; LOGIN@ : l'heure laquelle cet utilisateur s'est connect ; IDLE : depuis combien de temps cet utilisateur est inactif (depuis combien de temps il n'a pas lanc de commande) ; WHAT : la commande qu'il est en train d'excuter en ce moment. En gnral, si vous voyez bash, cela signie que l'invite de commandes est ouverte et qu'aucune commande particulire n'est excute. Dans mon cas, on voit donc deux utilisateurs (deux fois moi). Le premier correspond la session graphique : on le devine notamment grce la dernire colonne WHAT qui indique que cet utilisateur est en train d'excuter l'environnement graphique Gnome. L'autre utilisateur est sur une console (ici, une console graphique lance depuis Gnome). Cet utilisateur est en train d'excuter. . . la commande w ! En eet, lorsque je lance w je me vois en train de l'excuter dans la liste des utilisateurs connects, c'est parfaitement normal.
ps
La commande w nous a permis de faire rapidement le point sur l'tat du systme. Allons plus loin, maintenant : nous allons apprendre lister les processus qui tournent sur votre machine. Pour faire simple, dites-vous qu'un processus est un programme qui tourne en mmoire. La plupart des programmes ne font tourner qu'un processus en mmoire (une seule version d'eux-mmes). C'est le cas d'OpenOce par exemple. D'autres lancent des copies d'eux-mmes, c'est le cas du navigateur Google Chrome qui cre autant de processus en mmoire que d'onglets ouverts. 299
CHAPITRE 19.
Sur un serveur web, on utilise en gnral le logiciel Apache qui dlivre les pages web aux internautes. Ce logiciel cre beaucoup de processus pour sparer ses activits. Il en va de mme pour les systmes de gestion de bases de donnes, comme MySQL et PostgreSQL. Il ne faut pas s'inquiter si un programme gnre beaucoup de processus, cela n'est pas anormal.
Si vous faites la liste des processus qui tournent sur votre machine, vous risquez d'tre surpris. Vous en reconnatrez certains, mais vous en verrez beaucoup d'autres qui ont t lancs par le systme d'exploitation et dont vous n'avez jamais eu connaissance. Pour lister les processus qui tournent sous Windows, on utilise Ctrl + Alt + Suppr et on va dans l'onglet Processus . Sous Linux, on peut utiliser deux commandes direntes : ps et top.
ps
ps vous permet d'obtenir la liste des processus qui tournent au moment o vous lancez
la commande. Cette liste n'est pas actualise en temps rel, contrairement ce que fait top et qu'on verra plus tard. Essayons d'utiliser ps sans paramtre :
6 ps sh PQUPH ptsGH PWWRI ptsGH swi gwh HHXHHXHI sh HHXHHXHH ps
On distingue quatre colonnes. PID : c'est le numro d'identication du processus. Chaque processus a un numro unique qui permet de l'identier. Ce numro nous sera utile plus tard lorsque nous voudrons arrter le processus. TTY : c'est le nom de la console depuis laquelle a t lanc le processus. TIME : la dure d'excution du processus. Plus exactement, cela correspond la dure pendant laquelle le processus a occup le processeur depuis son lancement. CMD : le programme qui a gnr ce processus. Si vous voyez plusieurs fois le mme programme, c'est que celui-ci s'est dupliqu en plusieurs processus (c'est le cas de MySQL, par exemple). Dans mon cas, on distingue deux processus : bash (qui correspond l'invite de commandes qui gre les commandes) et ps que je viens de lancer.
PS
&
TOP
console (ici pts/0 ). Cela limite normment les processus achs, car beaucoup sont lancs par root (l'utilisateur administrateur de la machine) et ne sont pas lancs depuis la mme console que la vtre. La commande ps vous permet d'utiliser normment d'options. Regardez le manuel pour avoir une petite ide de tout ce que vous pouvez faire avec, vous allez prendre peur. Plutt que de faire une longue liste des paramtres possibles, je vous propose quelques combinaisons de paramtres utiles retenir.
ps -ef
Avec ps -ef, vous pouvez avoir la liste de tous les processus lancs par tous les utilisateurs sur toutes les consoles :
6 ps Eef sh sh root I root P root Q root R root S root T root U root QH root PRTP root QPWP root QRRV root RHPI root RHPP root RHPR root RHPU root RHQH root RHRH root RPTT root RQTQ root RRIU klog RRIW IHQ RRRH IHU RRST FFF sh H I I I I I I U I U U I I I I I I I I I I I I g H H H H H H H H H H H H H H H H H H swi HIXHI HIXHI HIXHI HIXHI HIXHI HIXHI HIXHI HIXHI HIXHI HIXHI HIXHI HIXHP HIXHP HIXHP HIXHP HIXHP HIXHP HIXHP c c c c c c c c c c c ttyR ttyS ttyP ttyQ ttyI ttyT c swi gwh HHXHHXHI GsinGinit HHXHHXHH migrtionGH HHXHHXHH ksoftirqdGH HHXHHXHH wthdogGH HHXHHXHH eventsGH HHXHHXHH khelper HHXHHXHH kthred HHXHHXHH klokdGH HHXHHXHH GsinGudevd EEdemon HHXHHXHH kpsmoused HHXHHXHH kgmeportd HHXHHXHH GsinGgetty QVRHH ttyR HHXHHXHH GsinGgetty QVRHH ttyS HHXHHXHH GsinGgetty QVRHH ttyP HHXHHXHH GsinGgetty QVRHH ttyQ HHXHHXHH GsinGgetty QVRHH ttyI HHXHHXHH GsinGgetty QVRHH ttyT HHXHHXHH GusrGsinGpid E GetGpiGeve HHXHHXHH GsinGsyslogd HHXHHXHH GinGdd s I if GproGkmsg of Gv HHXHHXHH GsinGklogd E GvrGrunGklogdGkm HHXHHXHH GusrGinGdusEdemon EEsystem HHXHHXHQ GusrGsinGhld
CHAPITRE 19.
Vous noterez l'apparition de la colonne UID (User ID ) qui indique le nom de l'utilisateur qui a lanc la commande. Il y en a beaucoup, lancs par root automatiquement au dmarrage de la machine, dont vous n'avez jamais entendu parler.
ps -ejH
Cette option intressante vous permet de regrouper les processus sous forme d'arborescence. Plusieurs processus sont des enfants d'autres processus, cela vous permet de savoir qui est l'origine de quel processus.
6 ps Eejr sh qsh I I P I Q I R I S I T I U I QH I QI I QP I WQ I IIV I IIW I IPH I IPI I IWQH I IWQI I PHTI I PHTP I PHWR I PPTQ I QPWP I QRRV I RSPI RSPI RSQV RSQV RSQW RSQW RSST RSST RSTW RSTW RSUH RSTW RSWQ RSWQ RSWR RSWR RTPS RTPS SHIP SHIP SHSU SHSU SHVH SHIP SHVQ SHIP SHVW SHIP sh I c I c I c I c I c I c I c I c I c I c I c I c I c I c I c I c I c I c I c I c I c I c I c RSPI c RSQV c RSQW c RSST c RSTW c RSTW c RSWQ c RSWQ c RTPS ttyU SHIP c SHSU c SHIP c SHIP c SHIP c swi gwh HHXHHXHI init HHXHHXHH migrtionGH HHXHHXHH ksoftirqdGH HHXHHXHH wthdogGH HHXHHXHH eventsGH HHXHHXHH khelper HHXHHXHH kthred HHXHHXHH klokdGH HHXHHXHH kpid HHXHHXHH kpinotify HHXHHXHH kseriod HHXHHXHR pdflush HHXHHXHH pdflush HHXHHXHI kswpdH HHXHHXHH ioGH HHXHHXHH ksuspendusd HHXHHXHH khud HHXHHXHH tGH HHXHHXHH tux HHXHHXHH ssiehH HHXHHXHW kjournld HHXHHXHH kpsmoused HHXHHXHH kgmeportd HHXHHXHH xetworkwnger HHXHHXHI vhiEdemon HHXHHXHH vhiEdemon HHXHHXHH xetworkwngerh HHXHHXHH systemEtoolsE HHXHHXHH dusEdemon HHXHHXHH gdm HHXHHXHH gdm HHXHSXST org HHXHHXHI gnomeEsession HHXHHXHH sshEgent HHXHHXPS metity HHXHHXIT gnomeEpnel HHXHHXQI nutilus
302
PS
SHWV SIHP SIHU SIIP RTRH RTUP SHIP SHIP SHIP SHIP RTRH RTUP SHIP SHIP SHIP SHIP RTRH RTUP c c c c c c HHXHHXHI HHXHHXHI HHXHHXHP HHXHIXIV HHXHHXHS HHXHHXHH
&
TOP
upsd hpiod
Dans cette liste, vous pouvez voir que kthread (ici surlign) a lanc lui-mme de nombreux processus, comme kacpid, pdflush. . . Certains processus que nous connaissons mieux nous apprennent des choses sur l'organisation du systme. C'est le cas ici de gdm (Gnome Desktop Manager ) qui gre tout le bureau Gnome. Il a lanc Xorg qui gre l'environnement graphique, mais aussi gnome-session qui gre tous les programmes que vous avez lancs durant cette session comme nautilus (l'explorateur de chiers), gnome-panel qui est plus ou moins l'quivalent de la barre des tches de Windows, etc.
ps -u UTILISATEUR
Pour ltrer un peu cette longue liste, on peut utiliser -u an d'obtenir par exemple uniquement les processus que l'on a lancs nous-mmes.
6 ps Eu mteoPI sh swi SHIP c HHXHHXHI SHSU c HHXHHXHH SHTH c HHXHHXHH SHTI c HHXHHXHH SHTQ c HHXHHXHQ SHTT c HHXHHXHH SHTV c HHXHHXHQ SHUS c HHXHHXHH SHUT c HHXHHXHH SHVH c HHXHHXPS SHVQ c HHXHHXIT SHVW c HHXHHXQI gwh gnomeEsession sshEgent dusElunh dusEdemon gonfdEP gnomeEkeyringEd gnomeEsettingsE sh esd metity gnomeEpnel nutilus
Ici, j'obtiens uniquement les processus lancs par l'utilisateur mateo21 , ce qui ltre dj pas mal les autres processus systme lancs par root.
top
La liste donne par ps a un dfaut : elle est statique (elle ne bouge pas). Or, votre ordinateur, lui, est en perptuel mouvement. De nombreux processus apparaissent et disparaissent rgulirement. Comment avoir une liste rgulirement mise jour ? Avec la commande top ! 303
CHAPITRE 19.
Essayez-la :
top E IQXQIXQH up IPXQHD Q usersD lod vergeX HFHID HFHUD HFII sksX WT totlD Q runningD WQ sleepingD H stoppedD H zomie gpu@sAX IFV7usD HFT7syD HFH7niD WUFS7idD HFH7wD HFH7hiD HFH7siD HFH7st wemX SISWVRk totlD RSQTSPk usedD TPQQPk freeD TWHQTk uffers wpX PRHWQPk totlD QIRWTk usedD PHWRQTk freeD PRTRHRk hed sh RTPS SHTV SIIP I P Q R S T U QH QI QP WQ IIV IIW IPH i root mteoPI mteoPI root root root root root root root root root root root root root root IS IS IS IV QR IH IH IH IH PH PH IH IS IS IH xs H H H H H IW H ES ES ES ES ES ES ES H H ES s QVSUP PWUTH RVTIP PWHV H H H H H H H H H H H H H i r 7g 7wiw IRm TTUT IFP PFW WFVm VHHV HFT IFW VRRH TVRR HFT IFT IVRV SPR HFH HFR H H HFH HFH H H HFH HFH H H HFH HFH H H HFH HFH H H HFH HFH H H HFH HFH H H HFH HFH H H HFH HFH H H HFH HFH H H HFH HFH H H HFH HFH H H HFH HFH H H HFH HFH swiC TXHIFHH HXHQFTW IXIWFRS HXHIFSH HXHHFHH HXHHFHI HXHHFHH HXHHFTT HXHHFHP HXHHFHH HXHHFSS HXHHFHH HXHHFHH HXHHFHP HXHRFVR HXHHFPH HXHIFPW gywwexh org gnomeEsettingsE gnomeEupsEion init migrtionGH ksoftirqdGH wthdogGH eventsGH khelper kthred klokdGH kpid kpinotify kseriod pdflush pdflush kswpdH
Cette liste est interactive et rgulirement mise jour. En haut, vous retrouvez l'uptime et la charge, mais aussi la quantit de processeur et de mmoire utilise. Nous n'entrerons pas dans les dtails ce niveau car cela demanderait un peu trop d'explications avances sur le fonctionnement du systme d'exploitation. Nanmoins, si vous savez lire la charge et la mmoire disponible, vous pouvez dj vous faire une ide de ce qui se passe. En dessous, vous avez la liste des processus.
qu'ils tiennent sur une page de la console. Par dfaut, les processus sont tris par taux d'utilisation du processeur (colonne %CPU). Les processus que vous voyez tout en haut de cette liste sont donc actuellement les plus gourmands en processeur. Ce sont peut-tre eux que vous devriez cibler en premier si vous sentez que votre systme est surcharg. On navigue l'intrieur de ce programme en appuyant sur certaines touches du clavier. 304
CTRL + C
&
KILL
: ARRTER UN PROCESSUS
En voil au moins deux connatre : q : ferme top ; h : ache l'aide, et donc la liste des touches utilisables.
Attention la dirence entre majuscules et minuscules ! Taper h n'a pas le mme eet que de taper H !
Mis part cela, voici quelques commandes connatre au sein de top qui peuvent vous tre utiles. B : met en gras certains lments. f : ajoute ou supprime des colonnes dans la liste. F : change la colonne selon laquelle les processus sont tris. En gnral, laisser le tri par dfaut en fonction de %CPU est susant. u : ltre en fonction de l'utilisateur que vous voulez. k : tue un processus, c'est--dire arrte ce processus. Ne vous inquitez pas, en gnral les processus ne sourent pas. On vous demandera le numro (PID) du processus que vous voulez tuer. Nous reviendrons sur l'arrt des processus un peu plus loin. s : change l'intervalle de temps entre chaque rafrachissement de la liste (par dfaut, c'est toutes les trois secondes). Vous voil pars utiliser top ! ;-) Je l'utilise principalement pour voir la charge voluer rgulirement tout en surveillant les processus les plus gourmands qui peuvent poser un problme.
Ctrl + C
Parfois, rien ne va plus. Un processus s'emballe et ne veut pas s'arrter. Cela arrive partout, mme sous Linux. la dirence de Windows toutefois, vous ne devriez pas avoir le rexe de redmarrer pour que a aille mieux . Tout peut tre rsolu en arrtant les processus qui vous gnent et en les relanant au besoin. Il y a plusieurs faons d'arrter un processus, nous allons les tudier ici.
Ctrl + C
La combinaison de touches Ctrl + C est connatre. Cela demande (gentiment) l'arrt du programme console en cours d'excution l'cran 2 . Prenez une commande qui n'en nit plus, comme par exemple un find sur l'ensemble du disque. Celui-ci va analyser tout votre disque dur la recherche du chier demand.
2. Ce raccourci se comporte ainsi en mode console seulement. En eet, en mode graphique, le comportement est le mme que sous Windows : cela permet d'eectuer une copie dans le presse-papier. Notez que pour copier-coller sous Linux, on utilise souvent une autre technique : on slectionne du texte et on clique avec la molette de la souris pour le coller ailleurs.
305
CHAPITRE 19.
Si vous trouvez cela trop long et que vous voulez arrter le programme en cours de route, il vous sut de taper Ctrl + C :
5 find G Enme 4BlogB4 GdevGlog GinGlogin GsysGmoduleGssimodGprmetersGssilogginglevel GsysGmoduleGehihdGprmetersGlogPirqthresh
La liste aurait d tre beaucoup plus longue. Mais j'ai demand l'arrt du programme avec Ctrl + C, ce qui fait que j'ai pu retrouver l'invite de commandes rapidement et facilement. Taper Ctrl + C ne coupe pas le programme brutalement, cela lui demande gentiment de s'arrter, comme si vous aviez cliqu sur la croix pour fermer une fentre.
kill
: tuer un processus
Ctrl + C ne fonctionne que sur un programme actuellement ouvert dans la console. De nombreux programmes tournent pourtant en arrire-plan, et Ctrl + C n'aura aucun
eet sur eux. C'est l que vous devez utiliser kill si vous voulez les arrter (on dit aussi tuer , c'est pareil mme si a a l'air violent). Pour vous en servir, il faudra auparavant rcuprer le PID du ou des processus que vous voulez tuer. Pour cela, deux solutions : ps ; top. Ces deux commandes que nous venons de voir vous indiquent le PID (numro d'identication) de chaque processus. Par exemple avec ps :
6 ps Eu mteoPI sh swi SHIP c HHXHHXHI SHSU c HHXHHXHH SHTH c HHXHHXHH SHTI c HHXHHXHH SHTQ c HHXHHXHQ SHTT c HHXHHXHH SHTV c HHXHHXHQ SHUS c HHXHHXHH SHUT c HHXHHXHH SHVH c HHXHHXPT SHVQ c HHXHHXIU FFF gwh gnomeEsession sshEgent dusElunh dusEdemon gonfdEP gnomeEkeyringEd gnomeEsettingsE sh esd metity gnomeEpnel
306
CTRL + C
&
KILL
: ARRTER UN PROCESSUS
sh mn pger ps
Supposons qu'on souhaite arrter Firefox. On peut ltrer cette longue liste avec grep et un pipe que nous avons appris utiliser.
6 ps Eu mteoPI | grep firefox QPTUV c HHXHHXHQ firefoxEin
Hop l, on a ltr Firefox de cette longue liste et on a mme rcupr son PID. Il ne nous reste plus qu' le tuer, avec la commande suivante :
kill QPTUV
Si tout va bien, la commande ne renvoie rien. Sinon, une erreur devrait s'acher dans la console. Vous pouvez aussi tuer plusieurs processus d'un seul coup en indiquant plusieurs PID la suite :
kill QPTUV PUTV QQHUI
Attention : mme si kill est par dfaut une commande gentille qui demande simplement au processus de s'arrter, vitez de tuer des processus que vous ne connaissez pas. Beaucoup d'entre eux sont essentiels au bon fonctionnement de votre systme, surtout ceux qui ont t lancs par root. J'ai essay, mais Firefox a l'air vraiment compltement plant et il refuse de s'arrter. Il n'y a pas moyen d'tre un peu plus. . . direct ?
Vous voulez tuer un processus sans lui laisser le choix ? C'est tout fait possible, mais n'utiliser que dans le cas d'un programme compltement plant que vous voulez vraiment arrter ! Avec kill -9 (comme le chire 9, oui, oui), vous demandez Linux de tuer le processus sans lui laisser le temps de s'arrter proprement. Cela peut faire le mnage quand rien ne va plus.
kill EW QPTUV
307
CHAPITRE 19.
. . . tuera le processus no 32678 (Firefox, dans mon cas) immdiatement sans lui laisser le temps de nir.
killall
Souvenez-vous : je vous ai dit que certains programmes se dupliquaient en plusieurs processus. Si vous voulez arrter l'ensemble de ces processus, comment faire ? Heureusement, vous avez des armes pour radiquer cette vermine. Vous pourriez, certes, tuer tous les processus en rcuprant un un leur PID. Mais il y a plus rapide : killall ( tuez-les tous ! ). Contrairement kill, killall attend le nom du processus tuer et non son PID. Supposons que nous ayons trois processus find en cours d'excution que nous souhaitions arrter.
6 ps Eu mteoPI | grep find TUS ptsGI HHXHHXHI find TUV ptsGP HHXHHXHH find TUW ptsGQ HHXHHXHI find
Si la commande ne renvoie rien, c'est que tout s'est bien pass. En revanche, si vous avez :
6 killll find findX uun proessus tu
. . . cela signie qu'il n'y avait aucun processus de ce nom tuer. Soit le processus n'est plus l, soit vous n'avez pas crit correctement son nom. Vriez ce nom nouveau avec la commande ps.
halt
Nous venons d'apprendre arrter des processus avec kill. Je pense que le moment est bien choisi pour dcouvrir comment arrter et redmarrer l'ordinateur. Comme je vous le disais plus tt, il est assez rare que l'on soit forc d'arrter ou de redmarrer l'ordinateur. moins d'avoir mis jour le kernel (noyau) de Linux, il n'est 308
HALT
&
REBOOT
jamais ncessaire de redmarrer. L'arrt et le redmarrage d'un serveur sous Linux sont rellement des oprations exceptionnelles.
Mais j'ai install Linux sur mon ordinateur personnel ! Je n'en fais pas un serveur. J'ai le droit de l'arrter ou de le redmarrer quand mme, non ?
En eet, et je suppose que vous n'avez pas attendu ce chapitre pour le faire. ;-) Vous pouviez arrter et redmarrer l'ordinateur via l'interface graphique (Gnome, KDE, . . .). Mais en console, savez-vous le faire ?
halt
: arrter l'ordinateur
La commande halt commande l'arrt immdiat de l'ordinateur. Il faut tre root pour arrter la machine ; vous devrez donc taper :
6 sudo hlt
reboot
: redmarrer l'ordinateur
De mme, il existe la commande reboot pour redmarrer l'ordinateur. Il faut nouveau tre root :
6 sudo reoot
Les commandes halt et reboot appellent en ralit la commande shutdown avec des paramtres spciques. N'hsitez pas lire sa page du manuel, vous verrez que vous pouvez par exemple programmer un arrt ou un redmarrage une heure prcise ou au bout d'un certain temps.
En rsum
Linux est multi-tches (plusieurs programmes peuvent tourner en mme temps) et multi-utilisateurs (plusieurs utilisateurs peuvent se servir de la mme machine en mme temps en s'y connectant via Internet). w indique quels utilisateurs sont sur la machine, ce qu'ils font et quelques autres statistiques comme la charge de travail de la machine et son uptime. 309
CHAPITRE 19.
ps ache la liste des processus, c'est--dire des programmes qui tournent sur la machine. top est un quivalent qui met jour automatiquement la liste au l du temps. La combinaison de touches Ctrl + C permet d'arrter une commande en cours d'excution dans la console an de pouvoir reprendre la main. kill tue un processus, ce qui signie qu'il lui demande de s'arrter. Il a besoin du numro du processus, gnralement fourni par ps ou top. Si le processus ne s'arrte pas, on peut utiliser le paramtre -9 qui coupe brutalement le processus (avec risque de perte de donnes). halt commande l'arrt de l'ordinateur, reboot son redmarrage.
310
Chapitre
20
Dicult :
ous avons commenc dcouvrir ce qu'taient les processus dans le chapitre prcdent. Nous savons dsormais comment les lister, les trier, les ltrer et enn comment les tuer. Ici, je vous propose d'aller plus loin et de dcouvrir l'excution en arrire-plan. A priori, la console a quelque chose de frustrant : on a l'impression qu'on ne peut lancer qu'un seul programme la fois par console. Or, c'est tout fait faux ! . . . Mais encore faut-il savoir comment faire tourner des programmes en arrire-plan. Il existe un certain nombre de techniques plus ou moins sophistiques. Il est recommand de les connatre car, parfois, on souhaite tout faire au sein d'une seule et mme console.
311
CHAPITRE 20.
&
Lorsque vous vous apprtez lancer une opration un peu longue, comme une grosse copie de chiers par exemple, vous n'avez peut-tre pas envie de patienter sagement le temps que la commande s'excute pour pouvoir faire autre chose en attendant. Certes, on peut ouvrir une autre console me direz-vous. Il y a des cas cependant o l'on n'a accs qu' une seule console, ou encore tout simplement pas envie d'en ouvrir une autre 1 . Contrairement aux apparences, plusieurs programmes peuvent tourner en mme temps au sein d'une mme console. Ce n'est pas parce qu'on ne peut pas acher plusieurs fentres comme dans un environnement graphique qu'on est bloqu sur un seul programme la fois ! Encore faut-il connatre les techniques qui permettent de lancer une commande en tche de fond. . .
&
La premire technique que je veux vous faire dcouvrir est trs simple : elle consiste rajouter le petit symbole & la n de la commande que vous voulez envoyer en arrire-plan.
Le symbole & s'appelle le et commercial ou encore l' esperluette . Il est prsent sur la touche 1 d'un clavier AZERTY.
Prenons par exemple la commande cp qui permet de copier des chiers. Je vous propose de copier un gros chier vido (ce qui prend en gnral du temps), comme ceci :
6 p videoFvi opievideoFvi 8 I ITSHR
312
&
&
NOHUP
Maintenant, vous ne voyez peut-tre rien, mais le processus est bel et bien en train de tourner en tche de fond . Si vous essayez de faire la mme chose avec d'autres commandes, par exemple sur un find, vous risquez d'tre surpris : les messages renvoys par la commande s'achent toujours dans la console ! Vous pouvez certes crire du texte et lancer d'autres commandes pendant ce temps (essayez), mais c'est un peu frustrant de voir ces messages apparatre dans la console ! Heureusement, vous savez maintenant rediriger la sortie pour ne pas tre importuns :
6 find G Enme 4Blog4 b sortiefind 8 I IVIWI
Les rsultats seront maintenant crits dans le chier sortiefind au lieu d'tre achs dans la console. De plus, la commande s'excute en fond et ne nous importune plus. Notez que pour tre srs de ne pas tre drangs du tout, vous devrez aussi rediriger les erreurs (par exemple avec 2>&1), ce qui peut nous donner une jolie commande comme celle-ci :
6 find G Enme 4Blog4 b sortiefind Pb8I 8 I IVPQI
Il reste toutefois un problme : le processus est attach votre console. Si vous fermez la console sur laquelle vous tes, le processus sera tu et ne s'excutera donc pas jusqu'au bout.
nohup
L'option &, bien qu'assez couramment utilise, a ce dfaut non ngligeable : le processus reste attach la console, ce qui veut dire que si la console est ferme ou que l'utilisateur se dconnecte, le processus sera automatiquement arrt. Si on veut que le processus continue, il faut lancer la commande via nohup. Cela s'utilise comme ceci :
nohup ommnde
313
CHAPITRE 20.
La sortie de la commande est par dfaut redirige vers un chier nohup.out. Aucun message ne risque donc d'apparatre dans la console. D'autre part, la commande est maintenant immunise contre la fermeture de la console. Elle continuera de fonctionner quoi qu'il arrive (sauf si on lui envoie un kill, bien sr).
est trs utile par exemple lorsque vous vous connectez un serveur. Imaginons que vous voulez lancer un programme (comme un serveur de jeu) : celui-ci s'arrtera de fonctionner ds que vous vous serez dconnects de la ligne de commandes du serveur. Vous n'allez pas rester connects juste pour que le programme continue fonctionner ! Heureusement, nohup vous prserve de ce problme.
nohup
Ctrl + Z, jobs, bg
Ctrl + Z
Reprenons le cas de notre grosse copie de chiers. Cette fois, je suppose que vous l'avez lance sans le petit symbole & :
6 p videoFvi videoopieFvi
Si vous n'avez pas de gros chier sous la main pour faire le test, vous pouvez aussi faire un top. Tapez maintenant Ctrl + Z pendant l'excution du programme. Celui-ci va s'arrter et vous allez immdiatement reprendre la main sur l'invite de commandes.
IC topped mteoPIdmteoPIEdesktopX~6 top
Vous noterez que nous avons plusieurs informations : le numro du processus en arrireplan (ici [1]), son tat (Stopped) et le nom de la commande qui a lanc ce processus. 314
CTRL + Z, JOBS, BG
&
FG
Le processus est maintenant dans un tat de pause. Il ne s'excute pas mais reste en mmoire.
bg
Maintenant que le processus est en pause et qu'on a rcupr l'invite de commandes, tapez :
6 g IC top 8
C'est tout, pas besoin de paramtre. Qu'est-ce que cela fait ? Cela commande la reprise du processus, mais cette fois en arrire-plan. Il continuera s'excuter nouveau, mais en tche de fond. En rsum, si vous avez lanc une commande par erreur en avant-plan et que vous voulez rcuprer l'invite de commandes, il faudra faire dans l'ordre : Ctrl + Z : pour mettre en pause le programme et rcuprer l'invite de commandes ; bg : pour que le processus continue tourner mais en arrire-plan.
jobs
Vous pouvez envoyer autant de processus en arrire-plan que vous voulez au sein d'une mme console : soit en les lanant directement en arrire-plan avec un & la n de la commande ; soit en utilisant la technique du Ctrl + Z suivi de bg que vous venez d'apprendre. Comment savoir maintenant quels sont les processus qui tournent en arrire-plan ? Vous pourriez, certes, recourir la commande ps, mais celle-ci vous donnera tous les processus. C'est un peu trop. Heureusement, il existe une commande qui liste uniquement les processus qui tournent en fond au sein d'une mme console : jobs.
6 jos IE topped PC topped top find G Enme 4BlogB4 b sortiefind Pb8I
Encore une fois, vous avez le numro du processus qui tourne en fond ( ne pas confondre avec le PID), son tat et son nom.
fg
CHAPITRE 20.
6 fg
Si vous avez un seul processus list dans les jobs, c'est ce processus qui sera remis au premier plan. Si, comme moi tout l'heure, vous avez plusieurs processus en arrireplan, il faudra prciser lequel vous voulez rcuprer. Par exemple, voici comment reprendre le find qui tait le job no 2 :
6 fg 7P
SCREEN
Par dfaut, un processus est lanc dans l'tat running l'avant-plan. On peut l'arrter avec la combinaison Ctrl + C, auquel cas il sera dtruit. Mais on peut aussi l'envoyer en arrire-plan. Si on l'excute ds le dpart avec un &, il sera l'tat running l'arrire-plan. Si on choisit de faire Ctrl + Z, il passera l'tat Stopped l'arrire-plan. Il faudra taper bg pour le faire passer nouveau l'tat running en arrire-plan. Enn, la commande fg renvoie un processus de l'arrire-plan vers l'avant-plan. Prenez cinq minutes pour bien analyser ce schma et vrier que vous avez compris l'essentiel de ce chapitre, c'est vraiment important. Il rsume peu prs tout ce qu'il faut savoir 2 .
screen
Il nous reste dcouvrir une commande un peu particulire que j'ai volontairement rserve pour la n : screen. Pourquoi ai-je attendu avant d'en parler ? Tout simplement parce que, contrairement ce que nous avons vu jusqu'ici, ce n'est pas une commande standard qui est installe par dfaut sur toutes les distributions Linux. Parfois, vous n'aurez pas accs screen (parce que vous n'tes pas root sur la machine) et il faudra vous dbrouiller avec les commandes que l'on vient de voir. Si toutefois vous tes les matres de la machine (ce qui est votre cas si vous avez install Linux chez vous), je peux vous recommander d'installer le programme screen.
6 sudo ptEget instll sreen
De quoi s'agit-il ? screen est un multiplicateur de terminal. Derrire ce nom un peu pompeux qui peut faire peur je le reconnais se cache en fait un programme capable de grer plusieurs consoles au sein d'une seule, un peu comme si chaque console tait une fentre !
Imaginez que screen est un programme qui permet entre autres de faire une mise en veille prolonge de votre console, tout comme vous le faites peuttre avec votre ordinateur portable qui se retrouve exactement dans l'tat o vous l'avez laiss en l'teignant. Concrtement, j'ai souvent tendance utiliser screen sur un serveur. Cela me permet par exemple de lancer un serveur de jeu dans une console screen, de quitter le serveur, puis de revenir l'administrer plus tard au besoin en rcuprant la console dans l'tat o je l'ai laisse.
Lorsque vous avez install screen, essayez-le en tapant tout simplement :
6 sreen
2. Il manque seulement nohup que j'ai mis part comme je vous l'ai dit.
317
CHAPITRE 20.
Un message s'ache, prcisant tout d'abord que le programme est un logiciel libre. Il indique ensuite l'adresse e-mail de l'auteur laquelle on peut envoyer, je cite des t-shirts, de l'argent, de la bire et des pizzas . Bon. . . passons. :-)
reen version RFHHFHQ @peA PQEytEHT gopyright @A IWWQEPHHP tuergen eigertD wihel hroeder gopyright @A IWVU yliver vumnn his progrm is free softwreY you n redistriute it ndGor modify it under the terms of the qx qenerl uli viense s pulished y the pree oftwre poundtionY either version PD or @t your optionA ny lter versionF his progrm is distriuted in the hope tht it will e usefulD ut sry ex eexY without even the implied wrrnty of wigrexefsvs or psxi py e esgve yiF ee the qx qenerl uli viense for more detilsF ou should hve reeived opy of the qx qenerl uli viense long with this progrm @see the file gysxqAY if notD write to the pree oftwre poundtionD snFD SW emple le E uite QQHD fostonD we HPIIIEIQHUD eF end ugreportsD fixesD enhnementsD tEshirtsD moneyD eer 8 pizz to sreenduniEerlngenFde ress pe or eturn to endF
Tapez Entre ou Espace pour passer ce message. premire vue, il ne se passe rien de bien extraordinaire : on retrouve une console vide. Mais mine de rien, nous nous trouvons dans une console mule , non pas dans la vraie console o nous tions tout l'heure. Vous pouvez en sortir en tapant Ctrl + D ou exit, comme si vous quittiez une console normalement. Vous retrouverez alors votre console habituelle o vous avez lanc screen :
mteoPIdmteoPIEdesktopX~6 sreen sreen is terminting
Bon, maintenant que vous savez sortir de screen, retournez-y. :-) Il faut savoir que sous screen, tout se fait partir de combinaisons de touches de la forme suivante : Ctrl + a + autre touche. En fait, vous devez taper Ctrl + a, relcher ces touches (lever les mains du clavier) et ensuite appuyer sur une autre touche.
Ctrl + a
Essayez de taper Ctrl + a, puis tapez ?. L'aide devrait alors s'acher : 318
SCREEN
reen key indingsD pge I of PF gommnd keyX e rek ler olon opy deth digrph displys dumptermp fit flow fous hrdopy help history info kill lstmsg f g X h d B F p p f s h c { } i u k w m liense loksreen log login met monitor next numer only other powrek powdeth prev quit reduf redisply remove D r v w d x e f h r ` v viterl eX x removeuf reset sreen selet silene split suspend time title vell version width windows wrp writeuf xoff xon a g 9 e q v b
x sp n
z t
p c l
w r s q
Il y a deux pages de commandes. Avec Espace vous allez la page suivante ; avec Entre, vous refermez l'aide. Comment lire cette page d'aide ? Par exemple, si vous voulez connatre la version du programme (milieu de la troisime colonne), il faudra taper Ctrl + a suivi de v (la lettre minuscule). Toutes les touches que vous voyez l doivent imprativement tre prcdes d'un Ctrl + a. Notez par ailleurs que l'accent circonexe ^ signie ici Ctrl.
CHAPITRE 20.
+ + + +
a a a a
puis Ctrl + a : revenir la dernire fentre utilise. puis un chire de 0 9 : passer la fentre no X. puis " : choisir la fentre dans laquelle on veut aller. puis k : fermer la fentre actuelle (kill ).
est sensible la casse pour les commandes ! Faites donc bien la dirence entre c et C par exemple.
screen
Il nous reste deux options trs intressantes de screen dcouvrir et qui mritent une attention particulire : split et detach.
Ctrl + a
Ctrl + a puis S coupe l'cran en deux pour acher deux consoles la fois (split ). Il est possible de rpter l'opration plusieurs fois pour couper en trois, quatre, ou plus (dans la mesure du possible, parce qu'aprs les consoles sont toutes petites). Voici, en gure 20.2, ce que vous voyez aprs avoir splitt l'cran une fois.
SCREEN
Vous pourrez, comme dans la gure 20.3, acher par exemple top pendant que vous faites des oprations sur la fentre du dessus.
Ctrl + a
Ctrl + a puis d dtache screen et vous permet de retrouver l'invite de commandes normale sans arrter screen. C'est peut-tre une des fonctionnalits les plus
utiles que nous devons approfondir, et cela nous ramne d'ailleurs l'excution de programmes en arrire-plan dont nous avons parl au dbut du chapitre. Concrtement, si vous dtachez screen, vous retrouvez l'invite de commandes classique :
mteoPIdmteoPIEdesktopX~6 sreen dethed mteoPIdmteoPIEdesktopX~6
L'information [detached] apparat pour signaler que screen tourne toujours et qu'il est dtach de la console actuelle. Il continuera donc tourner quoi qu'il arrive, mme si vous fermez la console dans laquelle vous vous trouvez. 321
CHAPITRE 20.
. . . pour retrouver votre session screen dans l'tat o vous l'avez laisse. Notez qu'il est possible de faire tourner plusieurs sessions screen en fond la fois. Dans ce cas, screen -r ne sera pas susant car on vous demandera de prciser quelle session vous voulez rcuprer :
6 sreen Er here re severl suitle sreens onX PHWQHFptsEHFmteoPIEdesktop @hethedA IWUIQFptsEHFmteoPIEdesktop @hethedA ype 4sreen Ed Er pidFttyFhost4 to resume one of themF
noter aussi que screen -ls ache la liste des screens actuellement ouverts :
6 sreen Els here re sreens onX PHWQHFptsEHFmteoPIEdesktop @hethedA IWUIQFptsEHFmteoPIEdesktop @hethedA P okets in GvrGrunGsreenGEmteoPIF
Certaines personnes ont pris l'habitude de tout faire sur screen, notamment sur les serveurs. Il m'est arriv de laisser tourner une session screen pendant plusieurs mois grce la possibilit de dtachement que nous venons de dcouvrir.
SCREEN
Ce chier s'appelle .screenrc et doit tre plac dans votre home (/home/mateo21 par exemple). Vous pouvez vous amuser lire la doc ce sujet, mais vous pouvez aussi utiliser le mme chier .screenrc que j'ai l'habitude d'utiliser 3 . Tlcharger le .screenrc Code web : 901904 Une fois plac dans votre home, excutez screen. Vous devriez noter quelques dirences, comme vous le montre la gure 20.4.
En rsum
Il est possible d'envoyer des programmes en arrire-plan dans la console an de garder la main pour lancer de nouvelles commandes. Pour lancer un processus en arrire-plan, on peut ajouter le symbole & la n de la commande. En revanche, lorsque vous fermez la console, le processus est arrt. Si vous voulez qu'il continue, utilisez plutt la commande nohup. Si vous avez lanc une commande normalement (en avant-plan) mais que celle-ci s'ternise, vous pouvez utiliser le raccourci Ctrl + Z pour la mettre en pause et rcuprer la main. Si vous lancez la commande bg ensuite, elle reprendra son excution en arrire-plan. Vous pourrez la rcuprer au premier plan avec fg tout moment.
3. Ce chier de conguration n'est pas de moi, merci donc son auteur, bennyben .
323
CHAPITRE 20.
screen est un programme puissant que vous pouvez installer avec apt-get (il n'est pas prsent par dfaut). Il permet d'ouvrir plusieurs consoles virtuelles au sein d'une seule et mme console, et donc d'excuter facilement plusieurs processus en parallle.
324
Chapitre
21
Dicult :
ous savons lancer une commande pour qu'elle s'excute tout de suite. Il est cependant aussi possible de retarder son lancement. Linux vous propose toute une srie d'outils qui vous permettent de programmer l'avance l'excution d'une tche, comme par exemple la crontab que nous allons tudier. Tous les outils que nous allons dcouvrir dans ce chapitre feront en outre appel la notion de date. Nous allons donc dans un premier temps nous intresser au formatage de la date.
325
CHAPITRE 21.
date
: rgler l'heure
Nous commencerons par nous intresser la date et l'heure du moment, car tout dans ce chapitre tourne autour de la notion de date. ;-) Je vous ai dj prsent brivement la commande date. Essayez-la nouveau :
6 dte merredi IH novemre PHIHD IPXPUXPS @gCHIHHA
Sans paramtre, la commande nous renvoie donc la date actuelle, l'heure et le dcalage horaire.
Le +%H est le format de date. %H signie le numro de l'heure actuelle . Il tait donc 12 heures au moment o j'ai lanc la commande. Essayons autre chose d'un peu plus compliqu :
6 dte 4C7rX7wX74 IPXQTXIS
Ici, j'ai rajout les minutes (%M) et les secondes (%S). J'ai spar les nombres par des deux-points, mais j'aurais trs bien pu mettre autre chose la place :
6 dte 4C7rh7wm7s4 IPhRImHIs
Seule la lettre qui suit le % est interprte. Mes lettres h , m et s sont donc simplement aches. 326
AT
vous de jouer !
Modier la date
La commande date permet aussi de changer la date.
Attention, il faudra tre root pour faire cela (vous devrez placer un devant par exemple).
sudo
Il faut prciser les informations sous la forme suivante : MMDDhhmmYYYY. Les lettres signient : MM : mois ; DD : jour ; hh : heure ; mm : minutes ; YYYY : anne. Notez qu'il n'est pas obligatoire de prciser l'anne. On peut donc crire :
6 sudo dte IIIHIPSH merredi IH novemre PHIHD IPXSHXHH @gCHIHHA
La nouvelle date s'ache automatiquement et elle est mise jour sur le systme. Attention bien respecter l'ordre des nombres : Mois - Jour - Heure - Minutes.
at
Vous souhaitez qu'une commande soit excute plus tard ? Pas de problme ! Il est possible de programmer l'excution d'une commande avec at.
CHAPITRE 21.
L'excution des commandes est demande 14 h 17 aujourd'hui. Si vous tapez cela dans votre console, vous devriez voir ceci s'acher :
6 t IRXIU wrningX ommnds will e exeuted using GinGsh tb
at comprend que vous voulez excuter des commandes 14 h 17 et vous demande lesquelles. C'est pour cela qu'un prompt est ach : on vous demande de taper les commandes que vous voulez excuter cette heure-l. Pour cet exemple, nous allons demander de crer un chier 14 h 17 :
6 t IRXIU wrningX ommnds will e exeuted using GinGsh tb touh fihierFtxt tb `iyb jo S t won xov IH IRXIUXHH PHIH
Aprs avoir crit la commande touch, at ache nouveau un prompt et vous demande une autre commande. Vous pouvez indiquer une autre commande excuter la mme heure. . . ou bien arrter l. Dans ce cas, tapez Ctrl + D (comme si vous cherchiez sortir d'un terminal). Le symbole <EOT> devrait alors s'acher, et at s'arrtera. at ache ensuite le numro associ cette tche ( ce job , comme il dit) et l'heure laquelle il sera excut. Attendez 14 h 17, et vous verrez que le chier sera cr. :-)
AT
6 t IRXIU tomorrow
La date est au format amricain, les numros du jour et du mois sont donc inverss : 11/15/10. 11 correspond au mois (novembre) et 15 au numro du jour !
. . . ce qui signie Dans maintenant (now ) + 5 minutes . Les mots-cls utilisables sont les suivants : minutes ; hours (heures) ; days (jours) ; weeks (semaines) ; months (mois) ; years (annes). Un autre exemple :
6 t now CP weeks
atq
Chaque fois qu'une commande est enregistre , at nous indique un numro de job ainsi que l'heure laquelle il sera excut. 329
CHAPITRE 21.
Il est possible d'avoir la liste des jobs en attente avec la commande atq :
6 tq IQ IP won xov IH IRXRRXHH PHIH mteoPI won xov IH IRXRPXHH PHIH mteoPI
Si vous souhaitez supprimer le job no 13 (je ne sais pas, parce que a porte malheur par exemple), utilisez atrm :
6 trm IQ
sleep
Le saviez-vous ? Vous pouvez enchaner plusieurs commandes la suite en les sparant par des points-virgules comme ceci :
6 touh fihierFtxtY rm fihierFtxt
touch est d'abord excut, puis une fois qu'il a ni ce sera le tour de rm (qui supprimera le chier que nous venons de crer). Parfois, enchaner les commandes comme ceci est bien pratique. . . mais on a besoin de faire une pause entre les deux. C'est l qu'intervient sleep : cette commande permet de faire une pause.
6 touh fihierFtxtY sleep IHY rm fihierFtxt
Cette fois, il va se passer les choses suivantes : fichier.txt est cr ; sleep fait une pause de 10 secondes ; rm supprime ensuite le chier. Par dfaut, la pause est exprime en secondes. Il est aussi possible d'utiliser d'autres symboles pour changer l'unit : m : minutes ; h : heures ; d : jours. Pour faire une pause d'une minute :
6 touh fihierFtxtY sleep ImY rm fihierFtxt
330
CRONTAB
L'intrt de sleep ne vous paratra peut-tre pas vident tout de suite, mais retenez que cette commande existe car il est parfois bien pratique de faire une pause, par exemple pour s'assurer que la premire commande a bien eu le temps de se terminer. ;-)
Vous pouvez aussi remplacer les points-virgules par des &&, comme ceci :
touh fihierFtxt 88 sleep IH 88 rm fihierFtxt
Dans ce cas, les instructions ne s'enchaneront que si elles se sont correctement excutes. Par exemple, si touch renvoie une erreur pour une raison ou une autre, alors les commandes qui suivent (sleep, rm) ne seront pas excutes.
crontab
La crontab constitue un incontournable sous Linux : cet outil nous permet de programmer l'excution rgulire d'un programme. Contrairement at qui n'excutera le programme qu'une seule fois, crontab permet de faire en sorte que l'excution soit rpte : toutes les heures, toutes les minutes, tous les jours, tous les trois jours, etc.
Un peu de conguration. . .
Avant toute chose, nous devons modier notre conguration (notre chier .bashrc) pour demander ce que Nano soit l'diteur par dfaut. En gnral, c'est le programme vi qui fait oce d'diteur par dfaut. C'est un bon diteur de texte, mais bien plus complexe que Nano et je ne vous le prsenterai que plus tard. En attendant, rajoutez la ligne suivante la n de votre chier .bashrc :
export ihsyanno
Cela aura pour eet d'crire cette ligne la n de votre chier .bashrc situ dans votre rpertoire personnel. Fermez ensuite votre console et rouvrez-la pour que cette nouvelle conguration soit bien prise en compte. Cette petite conguration tant faite, attaquons les choses srieuses.
la crontab . Ce chier contient la liste des programmes que vous souhaitez excuter
331
CHAPITRE 21.
le premier permet de modier la liste des programmes excuter, le second les excute.
Comment utilise-t-on crontab ? Il y a trois paramtres dirents connatre, pas plus : -e : modier la crontab ; -l : acher la crontab actuelle ; -r : supprimer votre crontab. Attention, la suppression est immdiate et sans conrmation ! Commenons par acher la crontab actuelle :
6 ront El no ront for mteoPI
Normalement, vous n'avez pas encore cr de crontab. Vous noterez qu'il y a une crontab par utilisateur. L j'dite la crontab de mateo21 car je suis logg avec l'utilisateur mateo21, mais root a aussi sa propre crontab. La preuve :
6 sudo ront El no ront for root
Si vous avez bien congur votre .bashrc tout l'heure (et que vous avez relanc votre console), cela devrait ouvrir le programme Nano que vous connaissez. Si par hasard vous n'avez pas fait quelque chose correctement, c'est le programme vi qui se lancera. Comme vous ne le connaissez pas encore, tapez :q puis Entre pour sortir. Vriez nouveau votre conguration du .bashrc et n'oubliez pas de fermer puis de rouvrir votre console.
Modier la crontab
Pour le moment, si votre crontab est vide comme la mienne, vous devriez voir uniquement ceci (capture d'cran de Nano) :
qx nno PFHFU pihier X GtmpGrontFRuRjrGront
332
CRONTAB
5 m h dom mon dow q eide uitter
veture de I ligne y rire vire fihF ge prFu gouper t tustifier gherher ge suivF goller
Les champs
Le chier ne contient qu'une seule ligne :
5 m h dom mon dow ommnd
Comme cette ligne est prcde d'un #, il s'agit d'un commentaire (qui sera donc ignor). Cette ligne vous donne quelques indications sur la syntaxe du chier : m : minutes (0 - 59) ; h : heures (0 - 23) ; dom (day of month ) : jour du mois (1 - 31) ; mon (month ) : mois (1 - 12) ; dow (day of week ) : jour de la semaine (0 - 6, 0 tant le dimanche) ; command : c'est la commande excuter. Chaque ligne du chier correspond une commande que l'on veut voir excute rgulirement. Vous trouverez en gure 21.1 un schma qui rsume la syntaxe d'une ligne.
CHAPITRE 21.
Imaginons que je veuille excuter une commande tous les jours 15 h 47. Je vais crire ceci :
RU IS B B B touh GhomeGmteoPIGfihierFtxt
Seules les deux premires valeurs sont prcises : les minutes et les heures. Chaque fois qu'il est 15 h 47, la commande indique la n sera excute.
J'ai crit le chemin du chier en entier, car vous ne pouvez pas tre srs que le cron s'excutera dans le rpertoire que vous voulez. Il est donc toujours prfrable d'crire le chemin du chier en absolu comme je l'ai fait ici : /home/mateo21/fichier.txt. Au fait, pourquoi passer par la commande crontab -e pour modier un chier ? Il ne serait pas plus simple d'ouvrir le chier directement avec nano .crontab, par exemple ?
Oui, mais ce n'est pas comme cela que a fonctionne. La crontab exige de passer par une commande, c'est comme a. Il y a quelques avantages cela, puisque cela permet au programme de vrier si votre chier est correctement crit avant de mettre jour la crontab. S'il y a une erreur de syntaxe, on vous le dira et aucun changement ne sera apport. Essayez d'enregistrer et de quitter Nano. Vous verrez que la crontab vous dit qu'elle installe les changements (elle les prend en compte, en quelque sorte) :
rontX instlling new ront mteoPIdmteoPIEdesktopX~6
Dsormais, fichier.txt sera cr dans mon rpertoire personnel tous les jours 15 h 47 (s'il n'existe pas dj). Revenez dans la crontab, nous allons voir d'autres exemples (tableau 21.1).
Est-il possible d'excuter une commande plus frquemment que toutes les minutes ?
Non, c'est impossible avec cron. La frquence minimale, c'est toutes les minutes.
CRONTAB
Crontab Signication
Toutes les heures 47 minutes exactement. Donc 00 h 47, 01 h 47, 02 h 47, etc. Tous les lundis minuit (dans la nuit de dimanche lundi). Tous les premiers du mois 4 h du matin. Tous les jours du mois de dcembre 4 h du matin. Toutes les heures les 4 dcembre. Toutes les minutes !
* : excut tout le temps (toutes les valeurs sont bonnes) ; 3,5,10 : excut lorsque le champ prend la valeur 3, 5 ou 10. Ne pas mettre d'espace aprs la virgule ; 3-7 : excut pour les valeurs 3 7 ; */3 : excut tous les multiples de 3 (par exemple 0 h, 3 h, 6 h, 9 h. . .). Vous connaissiez dj les deux premires notations. Celles que nous venons de dcouvrir nous permettent de dmultiplier les possibilits oertes par la crontab. Voici, sur le tableau 21.2, quelques exemples d'utilisation.
Crontab Signication
5 h 30 du matin du 1er au 15 de chaque mois. minuit le lundi, le mercredi et le jeudi. Toutes les 2 heures (00 h 00, 02 h 00, 04 h 00. . .) Toutes les 10 minutes du lundi au vendredi.
Comme vous le voyez, la crontab ore de trs larges possibilits (pour peu que l'on ait compris comment elle fonctionne).
Rediriger la sortie
Pour le moment, nous avons excut notre commande trs simplement dans la crontab :
RU IS B B B touh GhomeGmteoPIGfihierFtxt
Toutefois, il faut savoir que si la commande renvoie une information ou une erreur, vous ne la verrez pas apparatre dans la console. Normal : ce n'est pas vous qui excutez la commande, mais le programme cron. Que se passe-t-il alors si la commande renvoie un message ? En fait, le rsultat de la commande vous est envoy par e-mail. Chaque utilisateur possde sa propre bote 335
CHAPITRE 21.
e-mail sur les machines de type Unix, mais je ne vais pas m'attarder l-dessus. Nous allons plutt voir comment rediriger le rsultat. Tenez : rediriger une sortie, vous savez faire a, non ?
RU IS B B B touh GhomeGmteoPIGfihierFtxt bb GhomeGmteoPIGronFlog
Tous les messages seront dsormais ajouts la n de cron.log. Tous ? Non, on oublie d'y rediriger aussi les erreurs !
RU IS B B B touh GhomeGmteoPIGfihierFtxt bb GhomeGmteoPIGronFlog Pb8I
Voil, c'est mieux. Cette fois, tout sera envoy dans cron.log : les messages et les erreurs.
En rsum
date permet d'obtenir la date et l'heure mais aussi de modier celles-ci. at retarde l'excution d'une commande une heure ultrieure. On peut excuter plusieurs commandes d'ale en les sparant par des pointsvirgules : touch fichier.txt; rm fichier.txt. La commande sleep permet de faire une pause entre deux commandes excutes d'ale. crontab permet de programmer des commandes pour une excution rgulire. Par exemple : tous les jours 18 h 30, tous les lundis et mardis 12 h, tous les 5 du mois, etc. On modie la programmation avec crontab -e.
336
Quatrime partie
Transfrer des donnes travers le rseau
337
Chapitre
22
Dicult :
Archiver et compresser
our bien dbuter cette partie sur le rseau, il me semble logique de vous prsenter d'abord le fonctionnement de la compression sous Linux. En eet, si vous vous apprtez envoyer un ou plusieurs chiers par le rseau (que ce soit par mail, FTP ou autre), il est toujours prfrable de commencer par les compresser an de rduire leur taille. Vous avez srement dj entendu parler du format zip. C'est le plus connu et le plus rpandu. . . du moins sous Windows. On peut l'utiliser aussi sous Linux, de mme que le format rar. Cependant, on prfrera utiliser des alternatives libres (et souvent plus puissantes) telles que le gzip et le bzip2. Toutefois, contrairement zip et rar, le gzip et le bzip2 ne sont capables de compresser qu'un seul chier la fois et ne peuvent donc pas crer un paquetage de plusieurs chiers. Mais rassurez-vous, tout est prvu : on utilise pour cela un outil part, appel tar, qui permet d'assembler des chiers avant de les compresser. Nous allons dcouvrir le fonctionnement de tout cela dans ce chapitre. ;-)
339
CHAPITRE 22.
ARCHIVER ET COMPRESSER
tar
Comme je vous le disais en introduction, aussi tonnant que cela puisse paratre, les gzip et bzip2 ne permettent de compresser qu'un seul chier la fois. Comment faire alors si vous voulez compresser une dizaine de chiers ? Sous Linux, on a depuis longtemps pris l'habitude de procder en deux tapes : 1. runir les chiers dans un seul gros chier appel archive. On utilise pour cela le programme tar ; 2. compresser le gros chier ainsi obtenu l'aide de gzip ou de bzip2. Ces deux tapes sont rsumes dans le schma de la gure 22.1.
Les formats zip et rar ne sparent pas les tapes comme sur le schma 22.1. Ils sont capables d'assembler plusieurs chiers en une archive et de la compresser en mme temps.
Comme vous le voyez, sous Linux il y a donc une mthode suivre dans un ordre prcis. Voyons ensemble comment faire ! 340
TAR
Certains formats de chier sont dj compresss. C'est le cas des images jpeg, png et gif, mais aussi de la plupart des vidos. Vous pouvez bien entendu les assembler dans une archive tar et mme les compresser, mais vous ne les rendrez en gnral pas plus petits car ils ont dj t compresss.
Mes chiers .tuto que je souhaite archiver sont pour le moment placs en vrac dans mon home :
6 ls fureu smges lEheritgeFtuto houments lEsurhrgeEdEoperteursFtuto wodles ixmples lesEprinipuxEwidgetsFtuto wusique uli idos
Il est recommand de placer d'abord les chiers archiver dans un seul et mme dossier. Crons-le et dplaons-y tous nos .tuto :
6 mkdir tutoriels 6 mv BFtuto tutorielsG 6 ls fureu ixmples wodles uli houments smges wusique tutoriels
idos
-cvf
Nous allons maintenant crer une archive tar de ce dossier et de ses chiers. La procdure suivre pour crer une archive est :
tr Evf nomrhiveFtr nomdossierG
J'utilise trois options : -c : signie crer une archive tar ; -v : signie acher le dtail des oprations ; -f : signie assembler l'archive dans un chier. Essayons de faire cela sur notre dossier tutoriels : 341
CHAPITRE 22.
ARCHIVER ET COMPRESSER
Ici on archive le dossier tutoriels et donc son contenu. Grce -v, on voit bien la liste des chiers qui ont t archivs.
Est-on oblig de mettre systmatiquement nos chiers dans un mme dossier pour archiver ensuite ce dossier ? On ne pourrait pas archiver directement les chiers ?
Si, c'est possible. Imaginons que nous soyons toujours dans notre home avec nos chiers .tuto. On pourrait trs bien faire :
tr Evf rhiveFtr fihierI fihierP fihierQ
C'est possible et a fonctionne. Toutefois, il est de coutume sous Linux de placer d'abord les chiers dans un dossier avant de les mettre dans le tar. Cela permet d'viter, lorsqu'on extrait les chiers de l'archive, que ceux-ci aillent se mler d'autres chiers. Nous allons voir ce problme maintenant.
-tf
Vous venez de recevoir une archive tar qu'on vous a envoye. Bien. Mais que contientelle ? Avant d'extraire quoi que ce soit, vous aimeriez peut-tre voir son contenu. C'est possible avec -tf :
6 tr Etf tutorielsFtr tutorielsG tutorielsGlesEprinipuxEwidgetsFtuto tutorielsGlEsurhrgeEdEoperteursFtuto tutorielsGlEheritgeFtuto
Quand on fait cela, on voit que tous les chiers sont runis dans un mme dossier tutoriels, et a c'est trs pratique. J'en reviens justement au problme dont je parlais un peu plus haut : imaginez que vous dtariez une archive contenant plus de 400 chiers dans votre home. Si ces chiers n'taient pas runis dans un dossier, ils iraient tous se mler aux autres chiers du home, et alors l, je vous dis pas la pagaille ! Voil donc pourquoi je vous ai invits ds le dbut runir vos chiers archiver dans un mme dossier. Cela permet d'viter de mauvaises surprises celui qui extrait les 342
GZIP
&
BZIP2
chiers de l'archive. Quasiment toutes les archives que l'on vous proposera de tlcharger suivent ce mme schma et font attention tout runir dans un mme dossier, mais vriez le contenu avant de l'extraire, on ne sait jamais !
-rvf
: ajouter un chier
Si vous avez oubli un chier, vous pouvez toujours l'ajouter par la suite avec -rvf :
6 tr Ervf tutorielsFtr fihiersupplementireFtuto tutorielsGfihiersupplementireFtuto
-xvf
Pour extraire les chiers, on va utiliser les options -xvf (-x pour eXtract ) :
6 tr Exvf tutorielsFtr tutorielsG tutorielsGlesEprinipuxEwidgetsFtuto tutorielsGlEsurhrgeEdEoperteursFtuto tutorielsGlEheritgeFtuto
Les chiers s'extraient dans le rpertoire dans lequel vous vous trouvez. Vriez donc avant de les extraire que ceux-ci sont runis dans un mme dossier (avec -tf) si vous ne voulez pas que ces chiers aillent se mlanger d'autres !
gzip
Vous avez maintenant cr une belle archive tar. Tous vos chiers sont runis l-dedans. Voyons comment compresser cela. Nous disposons de deux programmes de compression bien rpandus dans le monde Linux : gzip : c'est le plus connu et le plus utilis ; bzip2 : il est un peu moins frquemment utilis. Il compresse mieux mais plus lentement que gzip.
noter qu'il existe aussi le vieux programme compress. Il n'est cependant plus vraiment utilis car on dispose aujourd'hui de meilleurs algorithmes de compression : gzip et bzip2.
Ces programmes sont simples utiliser. Ils prennent comme paramtre le nom du chier compresser. Ils le compressent et modient ensuite son nom. Concrtement, ils ajoutent un suxe pour indiquer que l'archive a t compresse : 343
CHAPITRE 22.
ARCHIVER ET COMPRESSER
.tar.gz : si l'archive a t compresse avec gzip ; .tar.bz2 : si l'archive a t compresse avec bzip2. titre indicatif, voici les direntes tailles de l'archive, avant et aprs compression :
tutoriels.tar tutoriels.tar.gz tutoriels.tar.bz2
Fichier
130 Ko 35 Ko 29 Ko
Taille
Cela conrme ce que je vous disais : bzip2 est plus ecace. . . mais il compresse aussi plus lentement et est moins frquemment utilis.
gzip
L'archive est compresse et gagne ensuite le suxe .gz. Elle s'appelle donc dsormais tutoriels.tar.gz. Voil pourquoi vous voyez circuler sur l'internet des chiers .tar.gz : cela signie que ce sont des archives compresses ! Pour dcompresser l'archive ensuite, il sut d'utiliser gunzip :
gunzip tutorielsFtrFgz
L'archive retrouve son tat non compress en .tar. Vous pouvez maintenant extraire les chiers de l'archive comme vous avez appris le faire un peu plus tt avec tar -xvf. ;-)
bzip2
Une archive compresse tutoriels.tar.bz2 sera alors cre. Pour la dcompresser, utilisez bunzip2 :
unzipP tutorielsFtrFzP
Vous retrouvez un .tar que vous pouvez extraire avec tar -xvf. 344
GZIP
&
BZIP2
Vous connaissez tar -cvf pour crer une archive tar. Si vous rajoutez l'option -z, l'archive sera automatiquement compresse avec gzip.
tr Ezvf tutorielsFtrFgz tutorielsG
Voil comment on obtient une archive compresse en une seule commande. :-) Pour dcompresser, c'est pareil, sauf que le -c est remplac par un -x comme tout l'heure :
tr Ezxvf tutorielsFtrFgz
-jcvf
Et pour extraire :
tr Ejxvf tutorielsFtrFzP tutorielsG
Vous pouvez toujours analyser le contenu de l'archive avant de la dcompresser. Avec -ztf, vous regarderez l'intrieur d'une archive gzippe et avec -jtf, vous regarderez l'intrieur d'une archive bzippe-deux .
345
CHAPITRE 22.
ARCHIVER ET COMPRESSER
zcat, zmore
Parfois, on compresse non pas une archive tar mais directement un chier. Par exemple, je peux compresser un chier .tuto directement :
gzip lEheritgeFtuto
Le chier est alors compress et renomm en l-heritage.tuto.gz. Maintenant, supposons que nous voulions acher le contenu de ce chier sans le dcompresser auparavant. Eh bien il existe des outils qui permettent de faire cela ! zcat : quivalent de cat, capable de lire un chier compress (gzipp). zmore : quivalent de more, capable de lire un chier compress (gzipp). zless : quivalent de less, capable de lire un chier compress (gzipp). Si vous essayez de faire un cat l-heritage.tuto.gz, vous allez voir des caractres bizarres s'acher l'cran, comme le montre la gure 22.2.
346
UNZIP
&
UNRAR
: DCOMPRESSER LES
.ZIP
ET
.RAR
`3gheege hpitre en impose peutEtre un peu pr s tilleD mis ne vous y fiez ps e sont surtout les shms qui prennent de l ple `imge legendea4YA4 smiliesa4I4bempltesGimgesGsmiliesGlinFpng`Gimgeb h9illeursD j9i volontirement vit de trop montrer de odes soures omplets diffrents et j9i prfr que vous vous folisiez sur es shmsF g9est e qu9on retient le mieux en gnrlD et permet de ien se reprerF v prtique viendr dns l prtie sur l liririe tF
zmore et zless, quivalents de more et less qui permettent d'acher page par page,
fonctionnent aussi !
unzip
Les .tar.gz et .tar.bz2 ont beau tre courants dans le monde Linux, vos amis utilisant Windows ne les connaissent pas et risquent tt ou tard de vous envoyer un superbe .zip ou .rar. . . que vous ne pouvez pas dcompresser avec gunzip. Heureusement, il existe des utilitaires de dcompression pour ces formats. Ils ne sont pas toujours installs par dfaut, il faudra donc les installer si vous ne les avez pas.
unzip
: dcompresser un .zip
Vous venez de recevoir un .zip ? Pas de panique ! Le programme unzip est capable de l'extraire. Il est peut-tre install par dfaut, mais si vous ne l'avez pas, vous savez ce qu'il vous reste faire :
sudo ptEget instll unzip
Les chiers vont s'extraire dans le dossier dans lequel vous vous trouvez ! Le problme est le mme qu'avec les .tar.gz et .tar.bz2. Avant de dcompresser, vriez si les chiers sont runis dans un mme dossier.
Pour voir le contenu d'une archive zip sans l'extraire, utilisez -l :
6 unzip El tutorielsFzip erhiveX tutorielsFzip vength hte ime EEEEEEEE EEEE EEEE
xme EEEE
347
CHAPITRE 22.
ARCHIVER ET COMPRESSER
H IIEIPEHV ISXHR SWSIS IIEIPEHV IRXRR QTUSU IIEIPEHV IRXRQ PUTVS IIEIPEHV IRXRR EEEEEEEE IPQWSU
On peut voir que les chiers sont runis dans un mme dossier dans l'archive. C'est plutt rare avec les .zip en principe, faites donc attention avant de dcompresser les chiers pour qu'ils n'atterrissent pas n'importe o. En gnral, on a surtout besoin d'unzip pour dcompresser un zip, mais il est peu frquent que l'on soit amen crer un chier zip (on prfrera toujours le gzip ou le bzip2). Si toutefois vous voulez vraiment crer un zip, installez le programme zip puis basez-vous sur la commande suivante :
zip Er tutorielsFzip tutorielsG
unrar
: dcompresser un .rar
Il vous faut installer le paquet unrar pour pouvoir utiliser cette commande :
sudo ptEget instll unrr
Non, vous ne rvez pas, l'auteur du programme ne veut pas que l'on mette un tiret devant l'option e ! Il faut bien qu'il y ait des exceptions dans la vie. :-) Pour lister le contenu avant dcompression, utilisez l'option l :
6 unrr l tutorielsFrr xe QFVH et P freewre erhive tutorielsFrr xme ize ked tio hte ime ettr gg weth e gopyright @A IWWQEPHHV elexnder oshl
348
UNZIP
&
UNRAR
: DCOMPRESSER LES
.ZIP
ET
.RAR
EEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEE lesEprinipuxEwidgetsFtuto SWSIS ITIWI PU7 IPEIIEHV IRXRR ErwErEErEE TiPTTVIP mQ PFW lEsurhrgeEdEoperteursFtuto QTUSU IIPIS QH7 IPEIIEHV IRXRQ ErwErEErEE iVRURSPV mQ PFW lEheritgeFtuto PUTVS VUPH QI7 IPEIIEHV IRXRR ErwErEErEE UQVipIPI mQ PFW EEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEEE Q IPQWSU QTIPT PW7
En rsum
Pour regrouper plusieurs chiers et dossiers au sein d'un mme chier (appel archive ), on utilise le programme tar. Celui-ci ne compresse pas les chiers par dfaut, contrairement zip. Il est possible de compresser une archive tar avec le programme gzip (trs couramment utilis) ou bzip2 (meilleure compression mais plus lente). Les archives non compresses ont l'extension .tar, les archives compresses ont l'extension .tar.gz (pour gzip) ou .tar.bz2 (pour bzip2). On utilise peu les formats de compression zip et rar sous Linux, mais il est possible de dcompresser ces types de chiers avec les programmes unzip et unrar. Ceux-ci ne sont en gnral pas installs par dfaut.
349
CHAPITRE 22.
ARCHIVER ET COMPRESSER
350
Chapitre
23
Dicult :
oici probablement l'un des chapitres les plus intressants de ce livre. Nous allons dcouvrir comment se connecter distance une machine quipe de Linux. Je vous en ai dj un peu parl au dbut de cet ouvrage : toutes les machines sous Linux peuvent tre congures pour que l'on s'y connecte distance, pour peu qu'elles restent allumes. Ici, nous n'allons pas seulement dcouvrir la connexion distance. Nous allons aussi essayer de comprendre comment cela fonctionne et comment les donnes sont scurises grce au protocole SSH. Ce chapitre sera donc l'occasion de dcouvrir de nouvelles notions sur le monde passionnant des rseaux et de la scurit (cryptographie).
351
CHAPITRE 23.
Prenons un cas concret : votre ordinateur chez vous est sous Linux, vous le laissez allum. Pendant la journe au boulot, vous avez besoin de lancer un tlchargement ou de rcuprer un document. Vous vous connectez distance sur votre machine et vous ouvrez une console comme si vous tiez en face de votre PC ! Tout ce que vous avez appris faire dans une console, vous pouvez le faire distance depuis n'importe quelle machine dans le monde.
Ce chapitre intressera en particulier ceux qui ont besoin d'apprendre grer un serveur ddi 1 . En eet, l'administration de serveur sous Linux se fait presque exclusivement en ligne de commande distance, l'aide de SSH.
Un serveur est un ordinateur qui reste allum 24 h / 24, 7 j / 7. Cet ordinateur est semblable au vtre (quoique souvent plus puissant et plus bruyant) : il possde un processeur, un ou plusieurs disques durs, etc. Le principe d'un serveur est de rester allum et connect l'internet tout le temps. Il ore des services. Par exemple, le Site du Zro possde plusieurs serveurs chargs de vous envoyer les pages web du site toute heure du jour et de la nuit. :-)
Le PC qui se connecte au serveur est appel le client. Nous allons les reprsenter comme sur la gure 23.1 dans les prochains schmas. Actuellement, votre petit PC chez vous n'est pas considr comme un serveur. . . mais vous pouvez trs facilement le transformer en serveur si vous le dsirez, condition
1. Et ils sont de plus en plus nombreux. Avoir son serveur permet d'hberger soi-mme son site web ou fournir des services, comme un serveur de jeux.
352
DE TELNET SSH
De Telnet SSH
Les protocoles
Pour communiquer entre eux en rseau, deux ordinateurs doivent utiliser le mme protocole. C'est un peu comme une langue : pour parler quelqu'un, vous devez parler la mme langue que lui, sinon vous ne vous comprendrez pas. Il existe de trs nombreux protocoles pour que les ordinateurs puissent communiquer entre eux. Il y en a un que vous avez forcment vu, c'est le HTTP (HyperText Transfer Protocol ). Si, si, regardez par exemple l'adresse du Site du Zro 3 . Le prxe http signie que vous communiquez avec les serveurs du Site du Zro l'aide du protocole HTTP. C'est le protocole utilis sur le web pour s'changer des pages web. Mais il existe bien d'autres protocoles ! Par exemple le FTP (File Transfer Protocol, protocole de transfert de chiers), l'IMAP (Internet Message Access Protocol, utilis pour s'changer des e-mails), etc.
353
CHAPITRE 23.
Voici ce qui pourrait se passer. Je force le trait, mais c'est pour vous donner une ide. Imaginez qu'un PC militaire demande un serveur de l'arme le code de lancement de missiles (nuclaires, soyons fous), comme sur la gure 23.2.
Euh. . . attends, l : moi, je veux juste me connecter distance ma machine ou un serveur pour avoir l'accs la console. Je ne vais pas changer de code de lancement de missiles nuclaires ! Je vois pas en quoi c'est un problme si quelqu'un sait que je suis en train de faire un grep sur ma machine, par exemple. . .
4. Non, ce n'est pas le sujet de ce chapitre de vous expliquer comment faire. ;-)
354
DE TELNET SSH
Figure 23.4 Wireshark intercepte les donnes qui circulent sur le rseau
a ne vous drange pas que l'on vous espionne ? Soit. Mais quand vous allez vous connecter au serveur, vous allez donner votre login et votre mot de passe. Rien que a, c'est dangereux (gure 23.5). Il ne faut pas que le login et le pass apparaissent en clair sur le rseau !
CHAPITRE 23.
Le cryptage symtrique
C'est la mthode de cryptage la plus simple. Cela ne veut pas dire qu'elle n'est pas robuste 5 . Cela veut plutt dire que le fonctionnement est simple comprendre. :-) Avec cette mthode, on utilise une cl (un mot de passe secret) pour crypter un message. Par exemple, imaginons que cette cl soit topsecret (gure 23.6). Pour dcrypter ensuite le message, on utilise cette mme cl (gure 23.7). . . Il faut donc que la personne qui crypte et celle qui dcrypte connaissent toutes deux cette cl qui sert crypter et dcrypter. Si le pirate intercepte un message crypt, il ne peut rien en faire s'il ne connat pas la cl secrte (gure 23.8) !
5. Il existe des cryptages symtriques trs srs.
356
357
CHAPITRE 23.
Ah. . . c'est bien, a ! Mais il faut que le client et le serveur connaissent tous les deux la cl de cryptage. Il faut donc que le client envoie d'abord au serveur la cl pour que celui-ci puisse dcrypter ses futurs messages. . .
Trs bonne remarque : je vois que vous suivez, c'est bien. ;-) En eet, pour que le schma que l'on vient de voir puisse fonctionner, il faut que le client et le serveur se soient transmis auparavant la cl magique qui sert crypter et dcrypter. Mais comment font-ils pour se l'changer ? S'ils l'envoient en clair, le pirate va pouvoir l'intercepter et sera ensuite capable de dcrypter tous les messages crypts qui passeront sur le rseau (voyez la gure 23.9) !
Le cryptage asymtrique
Le cryptage symtrique utilise une seule cl pour crypter et dcrypter. Le cryptage asymtrique, lui, utilise une cl pour crypter, et une autre pour dcrypter. Il y a donc deux cls : une cl dite publique qui sert crypter ; 358
une cl dite prive qui sert dcrypter. La cl publique ne sert qu' crypter. Avec ce type d'algorithme, on ne peut dcrypter un message que si l'on connat la cl prive. On demande l'ordinateur de gnrer une paire de cls : une prive et une publique. Elles vont ensemble 6 . Prenons un exemple et imaginons que : la cl publique soit 74A48vXX ; la cl prive soit 99o0pn9. Pour crypter, on utilise la cl publique, comme sur la gure 23.10.
L'algorithme de cryptage asymtrique le plus connu s'appelle RSA. Si vous voulez savoir comment RSA fonctionne et pourquoi il faut une cl dirente pour crypter et pour dcrypter, il existe sur le Site du Zro un tutoriel sur RSA. Je vous prviens : il faut aimer les maths.
6. Ne me demandez pas comment il les gnre ni pourquoi elles vont ensemble, c'est trop compliqu expliquer ici. Admettez simplement que l'ordinateur est capable de gnrer alatoirement un couple de cls qui vont ensemble.
359
CHAPITRE 23.
Le cryptage asymtrique est donc utilis seulement au dbut de la communication, an que les ordinateurs s'changent la cl de cryptage symtrique de manire
361
CHAPITRE 23.
scurise
Figure
23.17 Le client peut envoyer son login et son mot de passe de manire
CHAPITRE 23.
Lors de l'installation, vous devriez voir certaines tapes intressantes s'eectuer automatiquement :
greting rP e keyY this my tke some time FFF greting rP he keyY this my tke some time FFF B estrting ypenfh eure hell server sshd
yu
RSA et DSA sont deux algorithmes de cryptage asymtrique. Comme je vous l'ai dit plus tt, SSH peut travailler avec plusieurs algorithmes de cryptage dirents. Ce que vous voyez l est l'tape de cration d'une cl publique et d'une cl prive pour chacun des deux algorithmes (RSA et DSA). Ensuite, le programme de serveur SSH (appel sshd) est lanc. Normalement, le serveur SSH sera lanc chaque dmarrage. Si ce n'est pas le cas, vous pouvez le lancer tout moment avec la commande suivante :
7. Si vous voulez louer un serveur ddi, sachez qu'il existe de trs nombreux hbergeurs qui en proposent, comme par exemple OVH. Comme vous pourrez le constater, a cote cher (en mme temps, c'est un ordinateur part entire que vous louez !). Sachez qu'il existe aussi des serveurs low cost, moins chers (moins puissants mais ils peuvent sure), comme Kimsu et Dedibox. Je vous recommande d'attendre un peu avant de louer un serveur ddi : cela reprsente un gros investissement et il vaut mieux tre sr d'en avoir vraiment besoin.
364
Logiquement, vous ne devriez pas avoir besoin de congurer quoi que ce soit, mais sachez au besoin que le chier de conguration se trouve dans /etc/ssh/ssh_config. Il faudra recharger SSH avec la commande sudo /etc/init.d/ssh reload pour que les changements soient pris en compte. Voil : votre machine est dsormais un serveur SSH ! Vous pouvez vous y connecter depuis n'importe quel ordinateur sous Linux ou sous Windows dans le monde 8 . Nous commencerons dans un premier temps par voir comment accder votre PC distance depuis une machine Linux.
partir d'ici, je suppose que vous avez install openssh-server et que votre machine est allume. L'idal serait d'aller chez un ami qui a Linux (ou d'utiliser de chez vous un autre PC quip de Linux).
Ouvrez une console sur le second PC et utilisez la commande ssh comme ceci :
ssh logindip
Il faut remplacer login par votre login (mateo21, dans mon cas) et ip par l'adresse IP de votre ordinateur.
Si vous vous connectez depuis chez un ami, il vous faut entrer l'IP internet de votre PC que vous pouvez obtenir en allant sur www.whatismyip.com par exemple. Si vous vous connectez depuis un autre PC chez vous (sur le mme rseau local), il vous faut entrer l'IP locale que vous devriez voir en tapant la commande ifconfig (par exemple 192.168.0.3). Si vraiment vous n'avez ni ami sous Linux ni second PC dans la maison, vous pouvez simuler une connexion rseau en vous connectant depuis votre PC votre PC. Utilisez pour cela l'IP 127.0.0.1 (ou le mot localhost), a marche toujours.
8. Pour peu que vous ne soyez pas derrire un pare-feu.
365
CHAPITRE 23.
Obtenir votre IP Code web : 318222 Si je suis chez un ami et que l'IP internet de mon ordinateur est 87.112.13.165, je vais taper :
ssh mteoPIdVUFIIPFIQFITS
Si, faute de mieux, vous voulez tester en vous connectant chez vous depuis chez vous, vous pouvez taper :
ssh mteoPIdlolhost
Cette seconde mthode marche toujours, mais c'est moins impressionnant parce que vous ne faites que simuler une connexion rseau. Normalement, le serveur devrait rpondre au bout d'un moment et vous devriez voir quelque chose comme ce qui suit :
he uthentiity of host 9lolhost @IPUFHFHFIA9 n9t e estlishedF e key fingerprint is RWXdWXPdXPXdfXfdXVHXXeWXeXSWXQUXSVXQRXdeXfUF ere you sure you wnt to ontinue onneting @yesGnoAc
Si vous n'avez pas de rponse du serveur, vriez que vous ne vous tes pas tromps d'IP. Vriez aussi que le port 22 n'est pas bloqu par un pare-feu, car c'est celui utilis par SSH par dfaut. Si le serveur tourne sur un autre port, il faudra prciser le numro de ce port comme ceci : ssh mateo21@87.112.13.165 -p 12451 (si le serveur fonctionne sur le port 12451 au lieu du port 22).
49:d9:2d:2a:df:fd:80:ab:e9:eb:59:37:58:34:de:f7. C'est un numro unique qui vous per-
met d'identier le serveur. Si demain quelqu'un essaie de se faire passer pour le serveur, le ngerprint changera forcment et vous saurez qu'il se passe alors quelque chose d'anormal. Ne vous inquitez pas, SSH vous avertira de manire trs claire si cela arrive. En attendant, tapez yes pour conrmer que c'est bien le serveur auquel vous voulez vous connecter. Le serveur et le client vont alors s'changer une cl de cryptage, comme je vous l'ai expliqu un peu plus tt. Normalement, le serveur devrait vous demander au bout de quelques secondes votre mot de passe :
mteoPIdlolhost9s psswordX
Vous pouvez l'entrer en toute scurit, la communication est crypte. ;-) Si vous entrez le bon mot de passe, la console du PC de votre ami (ou votre propre console) devrait 366
vous acher un message de bienvenue puis un prompt qui correspond la console de votre PC. Bravo, vous tes connects !
mteoPIdmteoPIEdesktopX~6
Si aucune erreur ne s'ache, c'est que vous tes bien connects et que vous travaillez dsormais distance sur votre machine ! Vous pouvez eectuer toutes les oprations que vous voulez comme si vous tiez chez vous. Essayez de parcourir les dossiers pour voir que ce sont bien les vtres, et amusez-vous (pourquoi pas) crer un chier (avec Nano). Lorsque vous reviendrez sur votre PC, vous l'y retrouverez. Vous pouvez aussi commander l'excution d'un programme, d'une recherche, etc. Vous savez dj comment lancer un programme en tche de fond pour qu'il continue de s'excuter mme quand vous n'tes pas connects la machine 9 . Pour vous dconnecter, tapez logout ou son quivalent : la combinaison de touches Ctrl + D.
367
CHAPITRE 23.
J'ai donn quelques explications propos de l'adresse IP un peu plus haut, lorsque j'ai parl de la connexion SSH depuis Linux. Lisez donc les paragraphes prcdents si vous voulez plus d'informations ce sujet.
Dans mon cas, je vais entrer l'adresse IP de mon PC sous Linux situ sur mon rseau local (192.168.1.5 gure 23.19). Vous pouvez changer le numro du port si ce n'est pas 22, mais normalement c'est 22 par dfaut. Ensuite, vous n'avez plus qu' cliquer sur le bouton Open tout en bas pour lancer la connexion. Rien d'autre !
Si vous voulez sauvegarder l'IP et les paramtres pour ne pas devoir les retaper chaque fois, donnez un nom cette connexion (par exemple, le nom de votre ordinateur) dans le champ sous Saved Sessions , puis appuyez sur le bouton Save . La prochaine fois, vous n'aurez qu' double-cliquer sur le nom de votre PC dans la liste pour vous y connecter directement.
La premire fois que vous vous connectez votre serveur, PuTTY devrait vous demander une conrmation comme sur la gure 23.20. C'est la mme chose que sous Linux : on vous donne l'empreinte (ngerprint ) de votre 368
369
CHAPITRE 23.
serveur. Vous devez conrmer que c'est bien chez lui que vous voulez vous connecter. Cliquez sur Oui pour conrmer. l'avenir, on ne vous reposera plus la question. Par contre, si le ngerprint change, un gros message d'avertissement s'achera. Cela signiera soit que le serveur a t rinstall, soit que quelqu'un est en train de se faire passer pour le serveur (c'est ce que l'on appelle une attaque man-in-the-middle ). Cela ne devrait fort heureusement pas vous arriver, du moins je l'espre. :-) Le serveur vous demande alors le login et le mot de passe (gure 23.21).
Rappelez-vous qu'il est normal que les caractres ne s'achent pas quand vous tapez votre mot de passe. Il n'y a mme pas d'toiles pour des raisons de scurit, an que quelqu'un ne soit pas tent de compter le nombre de caractres en regardant derrire votre paule !
Si tout est bon, vous devriez tre connects votre machine (gure 23.22) ! Et voil, vous tes chez vous ! Vous pouvez faire ce qui vous chante : lire vos chiers, crire des chiers, lancer une recherche, excuter un programme. . . bref, vous tes chez vous. Pour vous dconnecter, tapez logout ou son quivalent, la combinaison de touches Ctrl + D. 370
Avec cette nouvelle mthode d'authentication, c'est le client qui va gnrer une cl publique et une cl prive. Les rles sont un peu inverss. L'avantage, c'est que l'on ne vous demandera pas votre mot de passe chaque fois pour vous connecter. Si vous vous connectez trs rgulirement un serveur, c'est vraiment utile. Si vous faites bien les choses, cette mthode est tout aussi sre que l'authentication par mot de passe.
Je vais, l encore, distinguer les deux cas : vous essayez de vous connecter depuis une machine Linux ; vous essayez de vous connecter depuis une machine Windows (avec PuTTY). 371
CHAPITRE 23.
Vous pouvez remplacer rsa par dsa si vous voulez utiliser l'autre algorithme de cryptage, mais a n'a pas vraiment d'importance ici. Lorsque vous tapez cette commande, vous allez voir plusieurs messages s'acher et il vous sera demand quelques petites prcisions :
6 sshEkeygen Et rs qenerting puliGprivte rs key pirF inter file in whih to sve the key @GhomeGmteoPIGFsshGidrsAX inter pssphrse @empty for no pssphrseAX inter sme pssphrse ginX our identifition hs een sved in GhomeGmteoPIGFsshGidrsF our puli key hs een sved in GhomeGmteoPIGFsshGidrsFpuF he key fingerprint isX UXPPXWRXXVXfXdQXefXSQXVTXdfXWXQUXRHXdXRd mteoPIdmteoPIElptop he key9s rndomrt imge isX CEE e PHRVEEEEC | | | | | F | | F F F i | | oFFF C | | oF oFFFF F | | FF FCFFFo | | oFFF FFFFo o | |ooCF ooF Fo F | CEEEEEEEEEEEEEEEEEC
Dans un premier temps, le client gnre une paire de cls ( Generating public/private rsa key pair ). Il doit ensuite sauvegarder ces cls dans des chiers (un pour la cl publique, un pour la cl prive). On vous propose une valeur par dfaut : je vous conseille de ne rien changer et de taper simplement Entre. Ensuite, on vous demande une passphrase. C'est une phrase de passe qui va servir crypter la cl prive pour une meilleure scurit. L, vous avez deux choix : 372
soit vous tapez Entre directement sans rien crire, et la cl ne sera pas crypte sur votre machine ; soit vous tapez un mot de passe de votre choix, et la cl sera crypte. Tout le monde ne met pas une phrase de passe. En fait, a dpend du risque que quelqu'un d'autre utilise la machine du client et puisse lire le chier contenant la trs secrte cl prive. Si le PC du client est votre PC chez vous et que personne d'autre ne l'utilise, il y a assez peu de risques ( moins d'avoir un virus, un spyware. . .). Si c'est en revanche un PC public, je vous recommande vivement de mettre une passphrase pour chirer la cl qui sera enregistre. Si vous hsitez entre les deux mthodes, je vous recommande de rentrer une passphrase : c'est quand mme la mthode la plus sre.
Les trois chiers sont : id_rsa : votre cl prive, qui doit rester secrte. Elle est crypte si vous avez rentr une passphrase ; id_rsa.pub : la cl publique que vous pouvez communiquer qui vous voulez, et que vous devez envoyer au serveur ; known_hosts : c'est la liste des fingerprint que votre PC de client tient jour. a lui permet de se souvenir de l'identit des serveurs et de vous avertir si, un jour, votre serveur est remplac par un autre (qui pourrait tre celui d'un pirate !). Je vous en ai dj parl un peu plus tt. L'opration consiste envoyer la cl publique (id_rsa.pub) au serveur et l'ajouter son chier authorized_keys (cls autorises). Le serveur y garde une liste des cls qu'il autorise se connecter. 373
CHAPITRE 23.
Le plus simple pour cela est d'utiliser la commande spciale ssh-copy-id. Utilisez-la comme ceci :
sshEopyEid Ei idrsFpu logindip
Si vous devez vous connecter au serveur par un autre port que celui par dfaut, basezvous sur la commande suivante : ssh-copy-id -i id_rsa.pub "-p 14521 mateo21@88.92.107.7". On vous demande votre mot de passe (celui de votre compte, pas la passphrase). En fait, vous vous connectez par mot de passe encore une fois, pour pouvoir ajouter votre cl publique sur le serveur. La cl est ensuite automatiquement ajoute ~/.ssh/authorized_keys sur le serveur. On vous invite vrier si l'opration s'est bien droule en ouvrant le chier authorized_keys, ce que vous pourrez faire plus tard si vous le voulez.
Se connecter !
Maintenant, connectez-vous au serveur comme vous le faisiez auparavant :
ssh logindip
Par exemple :
6 ssh mteoPIdVVFWPFIHUFU inter pssphrse for key 9GhomeGmteoPIGFsshGidrs9X
On vous demande la phrase de passe pour dcrypter votre cl prive. Entrez-la. Normalement, si tout va bien, vous devriez tre alors connects au serveur.
Ou je suis le dernier des nuls, ou alors c'est ce systme qui est nul. Auparavant, on me demandait mon mot de passe. Maintenant, on me demande une phrase de passe pour dcrypter la cl prive. O est le progrs ? ? ?
374
Je comprends votre frustration. ;-) En fait, si vous n'aviez pas mis de phrase de passe, on ne vous aurait rien demand et vous auriez t directement connects. Heureusement, il y a une solution pour ceux qui ont choisi la scurit en utilisant une phrase de passe, mais qui ne veulent quand mme pas avoir l'entrer chaque fois : l'agent SSH.
L'agent SSH
L'agent SSH est un programme qui tourne en arrire-plan en mmoire. Il retient les cls prives pendant toute la dure de votre session. Tout ce que vous avez faire est de lancer le programme ssh-add sur le PC du client :
6 sshEdd inter pssphrse for GhomeGmteoPIGFsshGidrsX sdentity ddedX GhomeGmteoPIGFsshGidrs @GhomeGmteoPIGFsshGidrsA
Il va automatiquement chercher votre cl prive. Pour la dcrypter, il vous demande la passphrase. Entrez-la. Maintenant que c'est fait, chaque fois que vous vous connecterez un serveur, vous n'aurez plus besoin d'entrer la passphrase. Essayez de vous connecter votre serveur pour voir !
L'intrt de l'agent SSH est qu'il ne vous demande la passphrase qu'une seule fois au dbut. Ensuite, vous pouvez vous connecter plusieurs fois sur le mme serveur, ou mme sur plusieurs serveurs dirents, le tout sans avoir besoin de retaper votre passphrase !
CHAPITRE 23.
Pour l'aider gnrer cette paire, le programme vous propose quelque chose d'assez amusant : vous devez bouger la souris dans la fentre (gure 23.24). Comme vous allez le faire alatoirement, cela aidera Puttygen gnrer des cls alatoires. Sous Linux, on utilise d'autres mthodes pour gnrer des cls alatoirement (il faut dire qu'en console, on n'a pas de souris).
Une fois que c'est fait, on vous ache la cl publique (gure 23.25) 10 . Vous pouvez choisir d'entrer une passphrase ou non. Comme je vous l'ai expliqu plus tt, cela renforce la scurit en cryptant la cl prive. Saisissez la passphrase dans les champs Key passphrase et Conrm passphrase . Ensuite, enregistrez la cl publique dans un chier en cliquant sur Save public key . Vous pouvez nommer ce chier comme vous voulez, par exemple cle.pub. Enregistrezle o vous voulez. Puis enregistrez la cl prive en cliquant sur Save private key . Donnez-lui l'extension .ppk : cle.ppk par exemple.
10. Comme vous le voyez, cela ne me drange pas que tout le monde voie ma cl publique. Le principe, c'est justement que tout le monde peut voir cette cl, mais ne peut rien en faire. Par contre, la cl prive doit rester secrte.
376
CHAPITRE 23.
Rajoutez votre cl publique la n du chier authorized_keys (s'il n'existe pas, il sera cr). Vous pouvez utiliser la commande suivante :
eho 4votrele4 bb uthorizedkeys
Rappel : votre cl publique est ache dans Puttygen, que vous ne devriez pas avoir ferm. Pour coller la cl dans la console, utilisez la combinaison de touches Shift + Inser plutt que Ctrl + V.
Par exemple :
eho 4sshErs eeeefQxzgIyPi FFF eeeefteCCfykvpHa rsEkeyEPHHVIIIU4 bb uthorizedkeys
Voil, c'est fait. ;-) Dconnectez-vous, et relancez PuTTY. On va maintenant le congurer pour qu'il se connecte l'aide de la cl.
Rglez la valeur de la liste droulante UTF-8, comme sur gure 23.26. La plupart des serveurs encodent dsormais les caractres en UTF-8, cela devrait donc vous viter des soucis d'achage. Maintenant, rendez-vous dans Connection SSH Auth. Cliquez sur le petit bouton Browse pour slectionner votre cl prive (gure 23.27). Je vous recommande aussi d'aller dans Connection Data et d'entrer votre login dans Auto-login username , comme la gure 23.28 vous le montre. Retournez l'accueil en cliquant sur la section Session tout en haut (gure 23.29). Entrez l'IP du serveur. Ensuite, je vous recommande fortement d'enregistrer ces paramtres. Donnez un nom votre serveur (par exemple MonServeur) sous Saved Sessions . Cliquez ensuite sur Save . l'avenir, vous n'aurez qu' double-cliquer sur le nom de votre serveur dans la liste pour vous y connecter directement avec les bons paramtres. Cliquez sur Open pour vous connecter au serveur. Vous devriez voir PuTTY utiliser automatiquement votre pseudo, puis vous demander votre passphrase. Entrez-la pour vrier que cela fonctionne, comme sur la gure 23.30.
Euh. . . et si je ne veux pas avoir entrer la passphrase chaque fois ? Non, parce que c'est pareil que d'entrer un mot de passe, l. . .
379
CHAPITRE 23.
CHAPITRE 23.
En eet, et ma rponse sera la mme que pour ceux qui se connectent depuis Linux : il faut utiliser un agent SSH. Ce programme va rester en mmoire et retenir votre cl prive. Il ne vous demandera la passphrase qu'une fois au dbut ; ensuite, vous pourrez vous connecter autant de fois que vous le souhaitez autant de serveurs que vous voulez sans avoir entrer quoi que ce soit.
Notez que si l'agent SSH Pageant est pratique, il vaut mieux l'arrter si vous devez vous absenter de votre ordinateur un long moment et que quelqu'un risque de l'utiliser. Sinon, n'importe qui peut se connecter vos serveurs sans avoir entrer de mot de passe. Retenez bien : l'agent SSH est un compromis entre la scurit et le ct pratique. Il retient les cls pour vous (du moins tant que le programme tourne). Si vous tes des utilisateurs intensifs de SSH, cela vous fera gagner beaucoup de temps.
Vous pouvez modier le raccourci qui lance Pageant pour que celui-ci charge votre 382
cl prive automatiquement ds son lancement. Faites un clic droit sur l'icne de Pageant , allez dans Proprits . Dans le champ Cible , rajoutez la n en paramtre le chemin de la cl charger. Par exemple :
4gXrogrm pilesupgentFexe4 XleFppk
En rsum
On peut se connecter distance un ordinateur quip de Linux et accder sa console. C'est comme cela que l'on administre les serveurs sous Linux. Le PC qui se connecte au serveur quip de Linux est appel le client. On peut se connecter une console Linux distance depuis n'importe quel autre systme d'exploitation (Windows, Mac OS ou Linux). Sous Windows, il faut installer le programme PuTTY pour se connecter distance un PC quip de Linux. Sous Linux et Mac OS, on utilise la commande ssh laquelle on indique son login et l'adresse IP de la machine. Par exemple : ssh mateo21@74.141.18.33. Les donnes qui sont changes entre le client et le serveur sont cryptes grce au protocole SSH an de garantir la condentialit des changes. Pour viter de devoir entrer son mot de passe chaque fois que l'on se connecte au serveur, on peut se crer une paire de cls d'identication. La cl publique ainsi gnre doit tre envoye sur le serveur, la cl prive restant sur le PC du client. La connexion se fait alors sans mot de passe et reste scurise.
383
CHAPITRE 23.
384
Chapitre
24
Dicult :
ous avez appris vous connecter un serveur distance avec SSH. Dsormais, grce au rseau, vous pouvez excuter des commandes sur un ordinateur en prenant le contrle distance. On continue ici notre dcouverte du monde fabuleux des rseaux sous Linux. Un monde un peu particulier, comme vous avez pu le dcouvrir : de gros eorts sont faits pour assurer la scurit des donnes grce au cryptage, ce qui permet d'viter de se faire voler ses donnes personnelles, comme son mot de passe par exemple. Dans ce chapitre, nous allons mettre l'accent sur le transfert de chiers : comment tlcharger un chier ? Comment se connecter un FTP, lire et tlcharger des chiers ? Et surtout, comment copier des chiers de manire scurise ?
385
CHAPITRE 24.
wget
: tlchargement de chiers
Nous commenons par une commande simple utiliser, du moins en apparence : wget. Elle permet de tlcharger des chiers directement depuis la console. Il sut d'indiquer l'adresse HTTP ou FTP d'un chier tlcharger :
6 wget httpXGGdimgeFdeinForgGdeinEdGRFHrSGiQVTGisoEdG deinERHrSEiQVTEusinessrdFiso
Les informations au dbut sont assez nombreuses et ne nous intressent pas vraiment. Elles indiquent simplement comment le programme a communiqu avec le serveur qui possdait le chier. En bas, vous avez, dans l'ordre et sur la dernire ligne : 1. 2. 3. 4. une barre de progression qui se met jour ; le nombre d'octets tlchargs ; la vitesse de tlchargement ; le temps restant estim (eta).
Vous pouvez arrter le tlchargement tout moment en utilisant la combinaison Ctrl + C que vous avez dj dcouverte.
WGET
: TLCHARGEMENT DE FICHIERS
Le plus simple est d'ouvrir un navigateur web tel que Firefox l o vous avez accs un environnement graphique et de faire un clic droit sur le lien du chier que vous voulez tlcharger, pour enn slectionner Copier l'adresse du lien . Vous pouvez ensuite le coller dans la console. Notez qu'il existe aussi des navigateurs en console tels que lynx (plutt basique) et links (assez complet) que vous pouvez tlcharger et essayer si vous le souhaitez.
Pour que cela fonctionne, il ne faut bien videmment pas supprimer le bout de chier tlcharg sur votre disque. ;-) Si la reprise a fonctionn vous devriez voir une barre de progression comme celle-ci :
UI7 CCCCCCCCCCCCCCCaaaaaaaaaaab PR RSH PIT RUHuGs et VVs
Les +++ correspondent la partie prcdemment tlcharge. Cela vous conrme que la reprise a bien fonctionn.
propose une quantit impressionnante d'options et je ne peux donc pas toutes les traiter. Sachez que vous pouvez notamment l'utiliser pour tlcharger des pages web. Consultez le manuel pour en savoir plus car il y a de quoi faire : man wget. Un des avantages de wget est que vous avez toujours une barre de progression, et cela mme si vous tlchargez un chier depuis un serveur FTP. a parat bte, mais, contrairement wget, le programme ftp que l'on verra plus loin ne donne pas l'avancement du tlchargement !
wget
387
CHAPITRE 24.
scp
Vous connaissez la commande cp ? Elle permet de copier des chiers sur votre disque dur. Eh bien voici scp (Secure CoPy ), qui permet de copier des chiers d'un ordinateur un autre travers le rseau ! Le tout de manire scurise, bien sr. :-)
Il existe aussi rcp (Remote CoPy ) qui fait la mme chose mais sans aucun cryptage. Son utilisation est dconseille.
scp s'utilise quasiment comme ssh. D'ailleurs ce n'est pas un hasard car scp s'appuie sur ssh pour fonctionner. L o ssh sert ouvrir une console distance (un shell), scp est spcialement conue pour copier des chiers d'un ordinateur un autre. On l'utilise comme ceci :
sp fihierorigine opiedestintion
Le premier lment indiquer est la position du chier que l'on veut copier. Le second lment correspond au rpertoire de destination o il doit tre copi. Chacun de ces lments peut s'crire sous la forme suivante : login@ip:nom_fichier. Le login et l'IP sont facultatifs. Si vous n'crivez ni login ni IP, scp considrera que le chier se trouve sur votre ordinateur.
Vous pouvez remplacer l'IP par un nom d'hte (un nom de domaine) si vous en avez un qui est plus facile retenir. Par exemple, le serveur Lisa du Site du Zro peut tre appel en crivant lisa.simple-it.fr au lieu d'une IP complique comme 85.123.10.201.
Ici, je demande copier le chier image.png qui se trouve sur mon ordinateur vers un autre ordinateur dont l'IP est 85.123.10.201. Sur cet autre ordinateur, le chier sera plac dans le dossier /home/mateo21/images/. Notez que l'on peut utiliser le symbole ~ pour indiquer mon rpertoire personnel (/home/mateo21/). D'autre part, si cet autre ordinateur a un nom d'hte facile retenir, j'aurais tendance l'utiliser la place de l'IP. J'aurais donc pu crire quelque chose comme ce qui suit et qui aurait t identique : 388
SCP
Lorsque vous lancez la commande, scp essaiera de se connecter au serveur ayant l'IP indique avec le login que vous avez demand (mateo21, dans mon cas). On vous demandera alors votre mot de passe ou, mieux, scp utilisera votre cl prive si elle existe 1 .
Dans cet exemple, je copie le chier image.png qui se trouve sur le serveur dont l'IP est 85.123.10.201 et place cette copie sur mon propre ordinateur sous le nom copie_image_sur_mon_pc.png. Si je veux, je peux aussi copier le chier sans en changer le nom :
sp mteoPIdVSFIPQFIHFPHIXimgeFpng F
Notez le point la n. Il signie copier dans le rpertoire dans lequel je me trouve . Le chier image.png sera donc plac sur mon ordinateur dans le dossier actuel.
Le pige du port
Si le serveur SSH auquel vous essayez de vous connecter n'est pas sur le port standard (22), il faudra indiquer le numro du port avec l'option -P :
1. Nous avons vu que, combin l'agent SSH, cela nous vitait d'avoir retaper notre passphrase chaque fois !
389
CHAPITRE 24.
La commande ssh a aussi une option pour indiquer un port ; vous vous en souvenez peut-tre, c'est. . . -p ! Faites donc attention car avec ssh c'est un p minuscule qu'il faut utiliser alors qu'avec scp c'est un P majuscule ! Je peux vous dire que je me suis tromp un bon nombre de fois.
ftp
Le FTP (File Transfer Protocol ) est un protocole permettant d'changer des chiers sur le rseau. Il est assez ancien (1985) et toujours utilis l'heure actuelle pour transfrer des chiers. On l'utilise en gnral dans deux cas. Pour tlcharger un chier depuis un serveur FTP public. En gnral, les navigateurs web font cela de manire automatique et transparente lorsque vous cliquez sur un lien de tlchargement. La connexion se fait alors en mode anonyme. Pour transfrer des chiers vers un serveur FTP priv (et ventuellement en tlcharger aussi). Lorsque l'on prend un hbergement pour son site web, l'hbergeur nous donne en gnral des accs FTP pour aller y dposer les chiers du site. La connexion se fait donc en mode authenti. Tout le monde n'a pas forcment accs un serveur FTP priv, aussi je vous propose pour les exemples suivants de vous connecter un serveur FTP public (rassurez-vous, si vous voulez vous connecter un FTP priv, la mthode reste la mme).
Nous nous intressons ici au fonctionnement du FTP en ligne de commande. Bien sr, il existe des logiciels graphiques qui font la mme chose, comme par exemple FileZilla.
390
FTP
&
SFTP
Le serveur FTP devrait rpondre en vous demandant un login et un mot de passe. Pour les serveurs FTP publics, le login utiliser est toujours anonymous (anonyme).
6 ftp ftpFdeinForg gonneted to ftpFdeinForgF PPH sensFdeinForg p server @vsftpdA xme @ftpFdeinForgXmteoPIAX nonymous QQI lese speify the psswordF sswordX
Pour le mot de passe, peu importe ce que vous mettez, vous serez accepts. :-) Vous devriez alors voir s'acher un message de bienvenue se terminant par :
PQH vogin suessfulF emote system type is xsF sing inry mode to trnsfer filesF ftpb
Vous avez maintenant un prompt 2 ftp> qui vous permet de rentrer des commandes FTP.
391
CHAPITRE 24.
ISH rere omes the diretory listingF drwxrwsrEx U IIUT IIUT RHWT he HS HWXIH dein PPT hiretory send yuF
Les lignes commenant par un numro sont des messages envoys par le serveur FTP. Vous noterez que les chiers s'achent comme si l'on avait crit ls -l. Il y a seulement un rpertoire, rendez-vous donc dans debian :
ftpb d dein PSH hiretory suessfully hngedF
PHXPW PHHH PHXPW IWXSP IWXSP IVXST PPXIT HWXHV HVXRW HVXRW PPXIT HWXHR
iehwi iehwiFghEmnufture iehwiFhtml iehwiFmirrorsFhtml iehwiFmirrorsFtxt dists do indies lsElFgz lsElFpthFgz pool projet
Le transfert de chiers
Si vous souhaitez rcuprer un chier ou en envoyer un, il y a deux commandes connatre (gure 24.3) : put : envoie un chier vers le serveur ; get : tlcharge un chier depuis le serveur.
Notez qu'il est impossible d'utiliser put sur les serveurs FTP publics comme celui auquel nous sommes connects. Seul le tlchargement de chiers est autoris. D'autres commandes, comme celle qui permet de changer les chmod des chiers, ne sont pas actives non plus.
Vous pouvez par exemple rcuprer le chier README en crivant get README : 392
FTP
&
SFTP
Et voil ! Le chier se trouve maintenant sur votre ordinateur. Il a t tlcharg dans le dossier dans lequel vous vous trouviez sur votre ordinateur. Pour savoir dans quel dossier vous tes chez vous, tapez !pwd :
ftpb 3pwd GhomeGmteoPI
Si vous voulez changer de dossier chez vous, utilisez !cd. Pour lister les chiers chez vous, utilisez !ls. Bref, vous m'avez compris, il sut de faire prcder les commandes d'un point d'exclamation pour qu'elles s'excutent chez vous et non sur le serveur FTP.
sftp
: un FTP scuris
Le protocole FTP a un dfaut : il n'est pas scuris ; les donnes ne sont pas cryptes. Quelqu'un ayant accs au rseau pourrait alors intercepter le contenu des chiers que vous changez ou encore votre mot de passe lors de la connexion. 393
CHAPITRE 24.
Pour remdier cela, on a invent sftp, qui repose sur SSH pour scuriser la connexion :
sftp logindip
Par exemple :
sftp mteoPIdlisFsimpleEitFfr
On vous demandera alors votre mot de passe 3 . Une fois que vous serez connects, les commandes sont presque les mmes que pour le FTP. Vous retrouverez notamment get et put pour changer des chiers. Sachez que les commandes sont globalement plus puissantes et pratiques en SFTP qu'en FTP. Mezvous toutefois, certaines commandes changent ! Par exemple, pour supprimer un chier, ce n'est plus delete mais nouveau rm ! Lisez le manuel pour plus d'informations : man sftp.
Pour se connecter en SFTP, on utilise le mme port que SSH (soit 22 par dfaut). Si votre serveur SSH fonctionne sur un autre port, vous devrez le prciser comme ceci : sftp -oPort=27401 mateo21@serveur.
l'heure actuelle, le SFTP reste assez peu utilis. Les hbergeurs web utilisent toujours le FTP classique alors que la plupart des logiciels graphiques comme FileZilla sont pourtant capables de se connecter en SFTP.
rsync
rsync est un programme assez simple utiliser et pourtant trs puissant. Il permet
d'eectuer une synchronisation entre deux rpertoires, que ce soit sur le mme PC ou entre deux ordinateurs relis en rseau. rsync est le plus souvent utilis pour eectuer des sauvegardes incrmentielles. Je m'explique. Par exemple, imaginez que vous souhaitiez sauvegarder rgulirement les chiers de votre home (rpertoire personnel). Ainsi, si un jour un accident survient (perte du PC, par exemple), vous aurez toujours vos documents sauvegards au chaud sur un serveur quelque part (gure 24.4). D'accord, vous copiez tout votre home sur ce serveur. Oui mais voil, votre home contient peut-tre 10 Go de chiers : entre vos vidos, la musique, vos rapports au format texte et vos photos de vacances, a va vite. Sauvegarder ces 10 Go une fois, d'accord. Mais la seconde fois, plutt que de tout renvoyer, vous souhaiterez peut-tre envoyer uniquement les chiers qui ont t ajouts ou modis, non ?
3. Bien entendu, la cl publique sera utilise, si elle est prsente.
394
RSYNC
Figure 24.5 rsync permet d'eectuer une sauvegarde incrmentielle rapide et ecace
395
CHAPITRE 24.
C'est l que rsync intervient. C'est une sorte de scp intelligent : il compare et analyse les dirences entre deux dossiers puis copie uniquement les changements. C'est ce que veut dire le mot incrmentiel . rsync peut tre utilis pour eectuer une sauvegarde entre deux dossiers sur le mme ordinateur ou bien entre deux dossiers sur deux ordinateurs dirents (gure 24.5). En gnral, on l'utilise plutt pour sauvegarder entre deux ordinateurs dirents, bien sr. Dans un premier temps, pour faire simple, nous allons voir comment fonctionne la sauvegarde entre deux dossiers de votre ordinateur puis nous eectuerons ensuite la sauvegarde sur un autre PC.
Vous pouvez crer comme moi des chiers de test l'aide de la commande touch. Maintenant, lancez un rsync comme ceci :
6 rsyn Erv smgesG kupsG sending inrementl file list reted diretory kups FG espgneIFjpg itlieIFjpg itliePFjpg itlieQFjpg sent PTV ytes reeived WI ytes UIVFHH ytesGse totl size is H speedup is HFHH
Quelques explications concernant les paramtres : -a : conserve toutes les informations sur les chiers, comme les droits (chmod), la date de modication, etc. ; -r : sauvegarde aussi tous les sous-dossiers qui se trouvent dans le dossier sauvegarder ; -v : mode verbeux, ache des informations dtailles sur la copie en cours. Viennent ensuite le nom du dossier sauvegarder et le rpertoire de sauvegarde. rsync analyse le contenu du rpertoire de sauvegarde dans un premier temps. Comme celui-ci est vide, vous pouvez constater qu'il y a copi tous les chiers. 396
RSYNC
Comme vous pouvez le voir, cette fois aucun chier n'a t envoy ! En eet, rsync tant intelligent, il a dtect qu'il n'y avait aucun changement et donc qu'il n'y avait pas lieu de copier quoi que ce soit. Testons un peu ce qui se passe si l'on ajoute un chier :
6 touh smgesGespgnePFjpg 6 rsyn Erv smgesG kupsG sending inrementl file list FG espgnePFjpg sent IUP ytes reeived QR ytes RIPFHH ytesGse totl size is H speedup is HFHH
Le nouveau chier espagne2.jpg a bien t copi ! ;-) Vous pouvez aussi essayer de modier un chier, vous verrez que rsync copie bien ceux qui ont t modis.
J'ai essay de supprimer un chier mais celui-ci n'a pas t supprim dans le rpertoire de sauvegarde. Comment faire ?
Par dfaut, rsync ne supprime pas les chiers dans le rpertoire de copie. Si vous voulez lui demander de le faire, pour que le contenu soit strictement identique, rajoutez --delete. Par exemple, si je supprime le chier italie3.jpg :
6 rm smgesGitlieQFjpg 6 rsyn Erv EEdelete smgesG kupsG sending inrementl file list deleting itlieQFjpg sent IPH ytes reeived IP ytes PTRFHH ytesGse totl size is R speedup is HFHQ
CHAPITRE 24.
Je vous recommande d'indiquer le rpertoire backup-dir en absolu comme je l'ai fait. Sinon, le rpertoire des chiers supprims sera plac l'intrieur du rpertoire de sauvegarde et vous risquez d'avoir plus de problmes qu'autre chose lors de la synchronisation.
rsync peut faire bien d'autres choses, comme exclure un dossier de la sauvegarde (option --exclude). Je vous laisse lire le manuel pour savoir un peu tout ce que vous
pouvez faire.
Si votre serveur SSH coute sur un autre port que celui par dfaut, il faudra rajouter -e "ssh -p port" :
6 rsyn Erv EEdelete EEkup EEkupEdiraGhomeGmteoPIGfihierssupprimes G smgesG mteoPIdsduserveurXmeskupsG Ee 4ssh Ep IPRUQ4
398
RSYNC
En rsum
wget permet de tlcharger un chier. Pour copier des chiers d'un ordinateur un autre, on utilise scp. Il fonctionne l'aide de SSH, donc le transfert est scuris. On peut se connecter un serveur FTP avec la commande ftp pour y tlcharger et y envoyer des chiers. Il existe une alternative scurise FTP qui crypte les changes grce SSH : sftp. rsync permet de synchroniser le contenu de deux dossiers sur un mme ordinateur ou sur deux ordinateurs dirents. Il est particulirement utile pour eectuer des sauvegardes.
399
CHAPITRE 24.
400
Chapitre
25
Dicult :
e chapitre vous propose d'apprendre matriser le trac rseau qui passe par votre ordinateur. En eet, lorsque vous tes connects l'internet, vous avez rgulirement des applications qui vont se connecter puis tlcharger et envoyer des informations. Comment surveiller ce qui se passe ? Quelle application est en train de communiquer et sur quel port ? Savoir paramtrer un pare-feu est essentiel, que ce soit sur votre PC la maison ou, plus forte raison, sur un serveur. Cela vous protge de manire ecace contre les programmes qui voudraient changer des informations sur le rseau sans votre accord. C'est une mesure de scurit essentielle qu'il faut connatre et dont aucun administrateur systme srieux ne peut se passer. ;-)
401
Je vous propose de dcouvrir d'abord quelques outils de base qui vont vous permettre de bien comprendre comment une IP est associe un nom d'hte. Puis nous analyserons le trac en cours avec un outil comme netstat. Enn et ce ne sera pas le plus facile, je vous prviens nous apprivoiserons le clbre pare-feu utilis sous Linux : iptables. Il est assez complexe paramtrer, mais heureusement des programmes supplmentaires peuvent nous simplier le travail.
host
Comme vous le savez srement, chaque ordinateur reli l'internet est identi par une adresse IP (gure 25.1). Une adresse IP est une suite de quatre nombres spars par des points. Par exemple : 86.172.120.28.
Cette adresse est au format IPv4. l'heure actuelle, c'est encore le type d'IP le plus utilis, mais ces adresses sont appeles petit petit tre remplaces par la norme IPv6. Bientt, tout le monde aura donc une IP qui ressemblera plutt quelque chose comme ceci : fe80::209:62fa:fb80:29f2.
Figure 25.1 Les ordinateurs sont identis sur le rseau par leur adresse IP
On peut associer chaque IP ce qu'on appelle un nom d'hte (hostname). C'est un nom en toutes lettres plus facile mmoriser et qui revient exactement au mme que d'crire l'adresse IP, comme le suggre la gure 25.2. Chaque serveur peut ainsi avoir un nom d'hte plus facile retenir. Je retiens mieux le nom de notre serveur (lisa.simple-it.fr) que son quivalent en adresse IP. :-) 402
HOST
&
WHOIS
: QUI TES-VOUS ?
La commande nous rpond que l'IP de siteduzero.com est 92.243.25.239. Elle nous indique par ailleurs le nom du serveur qui gre les e-mails. Maintenant, essayons l'envers avec l'IP :
6 host WPFPRQFPSFPQW IPQFPIWFPRVFVHFinEddrFrp domin nme pointer lisFsimpleEitFfrF
Oui, en fait il s'agit d'un synonyme dans le cas prsent : siteduzero.com = lisa.simple-it.fr. Vous pouvez essayer la mme manipulation avec d'autres IP et noms d'hte : prenez des sites que vous connaissez comme par exemple mozilla.org, google.fr, etc.
gauche l'IP, droite le nom d'hte correspondant. crire localhost est donc quivalent crire 127.0.0.1. Vous pouvez ajouter des lignes sur le mme modle pour faire correspondre une IP un nom d'hte. Quel intrt ? Cela dpend. Parfois, les DNS ne fonctionnent pas bien pendant de courtes priodes (c'est trs rare, mais a peut arriver). Dans ce cas, il est plus simple de modier votre chier hosts pour pouvoir continuer consulter votre site prfr en forant l'association du nom d'hte et de l'IP. Vous pourriez donc ajouter :
WPFPRQFPSFPQW siteduzeroFom
1. Si vous voulez en dcouvrir plus sur le fonctionnement des DNS, je vous invite lire mon tutoriel en ligne sur le Site du Zro (code web : 872971).
404
HOST
&
WHOIS
: QUI TES-VOUS ?
Attention : cette technique a l'avantage de forcer l'association, mais si notre serveur change un jour d'IP, votre ordinateur ne sera pas au courant ! En rgle gnrale, il est prfrable d'utiliser les serveurs DNS qui se mettent rgulirement jour (une fois par jour, en moyenne) an d'avoir toujours une liste actualise.
Sur un rseau local, il peut tre pratique d'associer un nom d'hte chaque PC pour pouvoir vous y connecter sans avoir retenir l'IP :
IWPFITVFHFS pEpp
Ainsi, crire pc-papa vous permet d'accder cet ordinateur sans avoir retenir l'adresse IP correspondante.
whois
Chaque nom de domaine doit obligatoirement indiquer qui se trouve derrire : nom, prnom, adresse et moyens de contact. C'est une rgle. L'outil whois vous permet d'obtenir facilement ces informations pour n'importe quel nom de domaine :
6 whois siteduzeroFom FFF dominX siteduzeroFom regretedX PHHPEHTEHW PIXSQXPW expiresX PHIIEHTEHW PIXSQXPW retedX PHHUEHPEPU HTXSTXRQ hngedX PHIHEHREIQ ISXQSXQP trnsferEprohiitedX yes nsHX FdnsFgndiFnet nsIX FdnsFgndiFnet nsPX FdnsFgndiFnet ownerEX niEhdlX hPSHHEqexhs ownerEnmeX imple s ev orgnistionX imple s ev personX ierre hfg ddressX PQ ue ve eletier zipodeX USHHW ityX ris ountryX prne
405
Utilisez ces informations avec parcimonie. En gnral, on y a recours lorsque l'on a besoin de contacter le propritaire d'un nom de domaine ou d'une adresse IP, pour rgler un litige mettant en jeu le nom de domaine ou l'IP en question par exemple.
ifconfig
Nous allons dcouvrir ici deux commandes : ifconfig et netstat. La premire permet de grer les connexions rseau de votre machine (pour les activer / dsactiver, par exemple) tandis que la seconde vous permet d'analyser ces connexions, de connatre des statistiques, etc.
ifconfig
Votre ordinateur possde en gnral plusieurs interfaces rseau, c'est--dire plusieurs moyens de se connecter au rseau. Tapez ifconfig dans la console pour voir ce que a donne :
6 ifonfig ethH vink enpXithernet rddr HHXWHXfSXSTXRRXS fyehge wvsge wXISHH wetriXI kets reusXH erreursXH~XH overrunsXH frmeXH pketsXH errorsXH droppedXH overrunsXH rrierXH ollisionsXH lg file trnsmissionXIHHH ytets reusXH @HFH fA ytets trnsmisXH @HFH fA snterruptionXPPH edresse de seXHxeHHH lo vink enpXfoule lole inet drXIPUFHFHFI wsqueXPSSFHFHFH dr inetTX XXIGIPV opeXrte vyyfegu xxsxq wXITRQT wetriXI kets reusXIH erreursXH XH overrunsXH frmeXH pketsXIH errorsXH droppedXH overrunsXH rrierXH ollisionsXH lg file trnsmissionXH ytets reusXSHH @SHHFH fA ytets trnsmisXSHH @SHHFH fA vink enpXithernet rddr HHXIWXdPXTIXWHXH inet drXIWPFITVFIFP fstXIWPFITVFIFPSS wsqueXPSSFPSSFPSSFH dr inetTX feVHXXPIWXdPffXfeTIXWHHGTR opeXvien fyehge xxsxq wvsge wXISHH wetriXI kets reusXSPQV erreursXH XH overrunsXH frmeXH pketsXRVWW errorsXH droppedXH overrunsXH rrierXH
wlnH
406
IFCONFIG
&
NETSTAT
ollisionsXH lg file trnsmissionXIHHH ytets reusXSHTWRRW @SFH wfA ytets trnsmisXIPHPRSW @IFP wfA
On distingue ici trois interfaces rseau. Vous en avez peut-tre plus, peut-tre moins ; tout dpend de votre ordinateur. Les interfaces que j'ai sont assez courantes, dtaillons-les : eth0 : cela correspond la connexion par cble rseau (ce qu'on appelle en gnral le cble RJ45 gure 25.3). Si votre PC est reli au rseau via un cble, c'est srement ce moyen de communication que vous utilisez actuellement. Notez que certains ordinateurs (et notamment les serveurs) ont plusieurs sorties rseau laires. Dans ce cas, vous devriez voir aussi des interfaces eth1, eth2, etc. lo : c'est la boucle locale. Tout le monde devrait avoir cette interface. Elle correspond une connexion . . . vous-mmes. C'est pour cela qu'on l'appelle la boucle locale : tout ce qui est envoy par l vous revient automatiquement. Cela peut paratre inutile, mais on a parfois besoin de se connecter soi-mme pour des raisons pratiques. wlan0 : il s'agit d'une connexion sans-l type Wi-Fi. L encore, bien que ce soit plus rare, si vous avez plusieurs cartes rseau sans l, vous aurez un wlan1, wlan2, etc.
Remplacez : interface par le nom de l'interface que vous voulez modier (eth0, wlan0. . .) ; etat par up ou down selon si vous voulez activer ou dsactiver l'interface. 407
Exemple :
6 ifonfig ethH down
. . . dsactive l'interface eth0 (laire). Plus aucun trac ne pourra alors circuler par l'interface eth0.
6 ifonfig ethH up
. . . la ractive de nouveau. Vous aurez peut-tre besoin de connatre ces commandes un jour ou l'autre si vous devez dsactiver puis ractiver une interface pour prendre en compte des changements dans la conguration de votre rseau.
netstat
La commande netstat risque de vous paratre un peu complexe si vous avez peu de connaissances concernant les rseaux, mais elle est incontournable quand on veut savoir ce que notre machine est en train de faire sur le rseau. netstat peut acher beaucoup d'informations. Pour slectionner celles qui nous intressent, on a recours de nombreux paramtres. Plutt que de les expliquer un par un, je vais vous montrer quelques combinaisons de paramtres qui donnent des rsultats intressants.
netstat -i
H H H
Vous n'aurez pas ncessairement les mmes lignes que moi ; tout dpend de votre ordinateur. Il s'agit l d'un tableau prsentant, pour chaque interface rseau que vous avez, une srie de statistiques d'utilisation. On retrouve ici nos interfaces eth0, lo et wlan0. 408
IFCONFIG
&
NETSTAT
Comme vous le voyez sur la colonne RX-ERR, c'est wlan0 qui est l'interface la plus active. Et vous noterez que lo est un petit peu utilise elle aussi ; comme quoi se connecter soi-mme peut s'avrer utile. Je ne rentrerai pas dans le dtail de ces colonnes car c'est assez technique, mais vous savez au moins dtecter l'activit de vos interfaces grce cette commande.
netstat -uta
6 netstt Eut gonnexions snternet roto evE endE tp H H tp H H tp H H tp I H tpT H H udp H H udp H H udp H H
Les options signient : -u : acher les connexions UDP ; -t : acher les connexions TCP ; -a : acher toutes les connexions quel que soit leur tat. TCP et UDP sont deux protocoles dirents pour envoyer des donnes sur le rseau. UDP est plutt utilis dans les jeux en rseau et pour les communications vocales (avec Skype, par exemple). Sinon, de manire gnrale, TCP est le protocole le plus utilis. Je n'irai pas plus loin dans les explications mais vous pouvez vous renseigner si le sujet vous intresse. Pour ltrer un peu, on va enlever les connexions UDP qui, la plupart du temps, sont moins importantes :
6 netstt Et gonnexions snternet roto evE endE tp H H tp H H tp H H tp H RIHU tpT H H tives @serveurs et tliesA edresse lole edresse distnte itt BXssh BXB vsix lolhostXipp BXB vsix mteoPIElptopFloXTHWWU deinEmirrorFmirroXftp iefvsri mteoPIElptopFloXQQUPI lisFsimpleEitFfrXwww iefvsrih XXXssh XXXB vsix
Ce tableau vous indique qui, depuis l'adresse locale, est connect qui ( une adresse distante). Chaque connexion a un tat. Ici, on repre les tats LISTEN et ESTABLISHED. De nombreux tats sont possibles ; en voici quelques-uns connatre : 409
ESTABLISHED : la connexion a t tablie avec l'ordinateur distant ; TIME_WAIT : la connexion attend le traitement de tous les paquets encore sur le rseau avant de commencer la fermeture ; CLOSE_WAIT : le serveur distant a arrt la connexion de lui-mme 2 ; CLOSED : la connexion n'est pas utilise ; CLOSING : la fermeture de la connexion est entame mais toutes les donnes n'ont pas encore t envoyes ; LISTEN : l'coute des connexions entrantes. Il y en a d'autres que vous pouvez lire dans la documentation. Globalement, ce qu'il faut retenir, c'est que les connexions l'tat LISTEN ne sont pas utilises actuellement mais qu'elles coutent le rseau au cas o quelqu'un veuille se connecter votre ordinateur. Regardez en particulier le port sur lequel ces connexions coutent (aprs le symbole : ) car c'est probablement l'information la plus intressante. En eet, on peut se connecter chaque ordinateur via direntes portes appeles ports. Chaque service utilise un port dirent, comme l'illustre la gure 25.4.
410
IFCONFIG
&
NETSTAT
tives @serveurs et tliesA edresse lole edresse distnte HFHFHFHXPP HFHFHFHXB IPUFHFHFIXTQI HFHFHFHXB IWPFITVFIFPXTHWWU IPVFIHIFPRHFPIPXPI IWPFITVFIFPXSRHHI VHFPRVFPIWFIPQXVH XXXPP XXXB
Cela correspond aux ports que l'on connat : 22 pour SSH, 21 pour FTP, 80 pour le web, etc.
netstat -lt
Trs utile, l'option -l vous permet de ltrer les connexions l'tat LISTEN et donc de savoir quels ports de serveur sont susceptibles d'tre utiliss en ce moment sur votre machine.
6 netstt Elt gonnexions snternet roto evE endE tp H H tp H H tpT H H tives @seulement serveursA edresse lole edresse distnte BXssh BXB lolhostXipp BXB XXXssh XXXB
netstat -s
: statistiques rsumes
Enn, si vous tes trs friands de statistiques rseau, -s est fait pour vous :
6 netstt Es spX URRQ pquets reus u totl I ve des enEttes invlides V ve des dresses invlides H rhemins H pquets rrivnt rejets UQSR pquets entrnts dlivrs UPPT requtes envoyes smpX H wessges sgw reus H messges sgw entrnt hous FFF
411
iptables
: le pare-feu de rfrence
Maintenant que nous savons analyser le trac rseau et ainsi voir un peu ce qui se passe, nous allons nous atteler au ltrage du trac l'aide d'un pare-feu. Le plus clbre pare-feu utilis sous Linux est iptables. Il permet d'tablir un certain nombre de rgles pour dire par quels ports on peut se connecter votre ordinateur, mais aussi quels ports vous avez le droit de vous connecter (gure 25.5). On peut galement ltrer par IP, mais nous ne dtaillerons pas cela ici.
Figure 25.5 Un pare-feu (ou rewall ) permet de bloquer l'accs certains ports
Par exemple, si je veux empcher toute connexion FTP (parce que je considre que le FTP n'est pas sr), je peux souhaiter bloquer le port 21 (utilis par FTP). En gnral la technique ne consiste pas bloquer certains ports mais plutt bloquer par dfaut tous les ports et en autoriser seulement quelques-uns.
Attends. . . c'est quoi le but, exactement ? Bloquer tout le trac rseau ? Pour quoi faire ?
C'est avant tout une question de scurit. Le but d'un pare-feu est d'empcher que des programmes puissent communiquer sur le rseau sans votre accord. Aujourd'hui, mme sous Windows 4 , un pare-feu est intgr par dfaut, tant le problme est important. Avoir un pare-feu ne vous prmunit pas contre les virus (bien que sous Linux, ils restent rares). En revanche, cela rend la tche particulirement dicile aux pirates qui voudraient accder votre machine. Vous vous souvenez de ce que je vous ai expliqu un peu plus tt ? Chaque ordinateur
4. Depuis Windows XP SP2
412
IPTABLES
: LE PARE-FEU DE RFRENCE
possde plusieurs portes d'entre possibles. Notre objectif est de bloquer par dfaut toutes ces portes et d'autoriser seulement celles dont vous avez besoin, que vous considrez comme sres et que vous utilisez. Par exemple, le port 80 utilis pour le web est un port sr que vous pouvez activer. Notez, et c'est important, qu'il y a des portes d'entre et des portes de sortie sur votre ordinateur (ce ne sont pas ncessairement les mmes).
iptables est un programme extrmement puissant, mais tout aussi complexe. Nous ne verrons que des fonctionnalits basiques 5 . Sachez qu'il peut faire bien plus que ce que l'on va voir : pour en savoir plus, comme d'habitude, lisez le manuel.
iptables
s'utilise en root
Pour manipuler iptables, vous devez imprativement tre en root . Pour la suite des oprations, je vous recommande donc de passer en superutilisateur ds prsent :
6 sudo su
iptables -L
Avec iptables -L (attention, un L majuscule), vous pouvez acher les rgles qui rgissent actuellement le pare-feu :
5 iptles Ev ghin sx @poliy eggiA trget prot opt soure ghin pyeh @poliy eggiA trget prot opt soure ghin y @poliy eggiA trget prot opt soure
413
On repre trois sections : Chain INPUT : correspond aux rgles manipulant le trac entrant ; Chain FORWARD : correspond aux rgles manipulant la redirection du trac ; Chain OUTPUT : correspond aux rgles manipulant le trac sortant. Nous ne verrons pas ici la section FORWARD. iptables permet de rediriger le trac, mais c'est assez compliqu et ne nous intresse pas ici. Nous aurons dj susamment de quoi faire avec INPUT et OUTPUT. Actuellement, chez moi, les rgles sont vides. Il y a trois tableaux mais qui ne contiennent aucune ligne. Par ailleurs, vous noterez chaque fois les mots (policy ACCEPT) qui signient que, par dfaut, tout le trac est accept. Donc chez moi, pour le moment, le pare-feu est tout simplement inactif car il ne bloque rien ; mon ordinateur est une vraie passoire. :-D Si vous avez dj des rgles inscrites dans votre pare-feu (ce qui ne devrait pas tre votre cas, mais on ne sait jamais), sachez que vous pouvez les rinitialiser. Ne le faites que si vous tes certains de vouloir le faire. En eet, sur un ordinateur partag, peut-tre quelqu'un a-t-il dj congur le pare-feu et il serait dommage de saboter tout son travail.
5 iptles Ep `EE ettention 3 initilise toutes les rgles iptles 3
Premire chose savoir : l'ordre des rgles est important. En eet, iptables les lit de haut en bas et la position de ces rgles inue sur le rsultat nal. Sachez donc que les rgles sont numrotes. Pour avoir les numros, ajoutez --line-numbers :
5 iptles Ev EElineEnumers ghin sx @poliy hyA num trget prot opt soure I eggi tp EE nywhere P eggi tp EE nywhere Q eggi tp EE nywhere
414
IPTABLES
: LE PARE-FEU DE RFRENCE
Ainsi, la rgle ltrant SSH est la rgle no 2. Chaque ligne correspond une rgle dirente qui permet de ltrer ou non une IP ou un port. Parmi les colonnes intressantes, on note : target : ce que fait la rgle. Ici c'est ACCEPT, c'est--dire que cette ligne autorise un port et / ou une IP ; prot : le protocole utilis (tcp, udp, icmp). Je rappelle que TCP est celui auquel on a le plus recourt. ICMP permet votre ordinateur de rpondre aux requtes de type ping ; source : l'IP de source. Pour INPUT, la source est l'ordinateur distant qui se connecte vous ; destination : l'IP de destination. Pour OUTPUT, c'est l'ordinateur auquel on se connecte ; la dernire colonne : elle indique le port aprs les deux points : . Ce port est ach en toutes lettres, mais avec -n vous pouvez obtenir le numro correspondant. Sur mon exemple, seuls les ports web, ssh et imap2 (e-mail) sont autoriss en entre. Personne ne peut se connecter la machine par un autre biais. En eet, si vous regardez bien, par dfaut j'ai congur le pare-feu pour qu'il ignore tous les autres paquets : (policy DROP). Nous allons maintenant apprendre faire tout cela.
Remplacez chain par la section qui vous intresse (INPUT ou OUTPUT), protocole par le nom du protocole ltrer (TCP, UDP, ICMP. . .) et enn dcision par la dcision 415
prendre : ACCEPT pour accepter le paquet, REJECT pour le rejeter ou bien DROP pour l'ignorer compltement. Le mieux est de dcouvrir comment on ajoute une rgle par une srie d'exemples. ;-)
5 iptles Ee sx Ep tp EEdport ssh Ej eggi
Cela ajoute la section INPUT (donc, pour le trac entrant) une rgle sur les donnes reues via le protocole TCP sur le port de ssh (vous pouvez remplacer ssh par le numro du port, soit 22). Lorsque votre ordinateur recevra des donnes en TCP sur le port de SSH, celles-ci seront acceptes ; cela vous permettra donc de vous connecter distance votre PC via SSH. Vous pouvez faire de mme avec d'autres ports :
5 iptles Ee sx Ep tp EEdport www Ej eggi
Si vous ne prcisez pas de port (en omettant la section dport), tous les ports seront accepts !
Comme je n'ai pas indiqu de section --dport, cette rgle s'applique tous les ports,
Votre ordinateur rpondra alors aux pings pour indiquer qu'il est bien en vie.
416
IPTABLES
: LE PARE-FEU DE RFRENCE
Ces deux rgles utilisent des options un peu direntes de celles que nous avons vues jusqu'ici. Voici quelques explications. 1. La premire rgle autorise tout le trac sur l'interface de loopback locale grce -i lo. Il n'y a pas de risque autoriser votre ordinateur communiquer avec lui-mme, d'autant plus qu'il en a parfois besoin ! 2. La seconde rgle autorise toutes les connexions qui sont dj l'tat ESTABLISHED ou RELATED. En clair, elle autorise toutes les connexions qui ont t demandes par votre PC. L encore, cela permet d'assouplir le pare-feu et de le rendre fonctionnel pour une utilisation quotidienne.
iptables devrait maintenant indiquer que par dfaut tout est refus, sauf ce qui est indiqu par les lignes dans le tableau :
417
5 iptles Ev ghin sx @poliy hyA trget prot opt soure eggi tp EE nywhere eggi tp EE nywhere eggi tp EE nywhere eggi imp EE nywhere
Le ltrage est radical. Nous n'avons pas autoris beaucoup de ports et il se pourrait que vous vous rendiez compte que certaines applications n'arrivent plus accder l'internet (normal, leur port doit tre ltr). vous de savoir quels ports ces applications utilisent pour modier les rgles en consquence. Au besoin, pensez faire de mme pour les rgles de sortie (OUTPUT).
Comme vous avez pu le constater, iptables est donc un pare-feu assez compliqu. Sachez que des dveloppeurs ont travaill sur un programme qui simplie l'utilisation d'iptables : ufw (Uncomplicated Firewall ). Contrairement iptables, ce programme n'est pas disponible partout, mais on le trouve dans les versions rcentes d'Ubuntu.
Dcouvrir ufw Code web : 370566
En rsum
Sur l'internet, chaque ordinateur est identi par une adresse IP. Par exemple : 86.172.120.28. On peut associer chaque adresse IP un nom d'hte, plus facile retenir, comme lisa.simple-it.fr. crire le nom d'hte est quivalent crire l'adresse IP. 418
IPTABLES
: LE PARE-FEU DE RFRENCE
La commande host permet de traduire une IP en nom d'hte et inversement. ifconfig liste les interfaces rseau (cartes rseau) de votre machine et permet de les congurer ainsi que de les activer. netstat ache la liste des connexions ouvertes sur votre machine. Elle indique notamment quel port est utilis chaque fois, le port reprsentant en quelque sorte la porte d'entre votre machine. Il est possible de bloquer l'accs certains ports avec le programme iptables, un pare-feu (rewall ) trs puissant. Celui-ci est cependant assez complexe congurer.
419
420
Chapitre
26
Dicult :
ous avons dcouvert dans un chapitre prcdent combien il tait facile d'installer de nouveaux programmes sous Ubuntu l'aide de la commande apt-get. Cette technique permet de tlcharger et installer la grande majorit des programmes. Cependant, il arrive parfois qu'il soit ncessaire d'installer un programme manuellement car il n'apparat pas dans apt-get. Dans ce cas, il faut rcuprer les sources du programme et les compiler soi-mme pour crer un excutable ! Cette opration peut se rvler assez complexe dans certains cas. Il nous faudra tlcharger les sources, les extraire d'une archive gzippe et les compiler manuellement. Je vous propose dans ce chapitre de mettre en pratique vos connaissances en dcouvrant pas pas la compilation d'un programme.
421
CHAPITRE 26.
422
423
CHAPITRE 26.
Ceci tant fait, nous pouvons prsent nous intresser la compilation proprement dite. Ici, je vous propose d'apprendre compiler un petit programme assez simple : htop 6 . Il s'agit d'un outil alternatif top, qui permet de voir la liste des programmes en cours d'excution. Cela sera l'occasion de dcouvrir les principales commandes de compilation qui vous serviront pour installer la plupart des logiciels. La premire tape consiste se rendre sur le site web du logiciel htop. Une recherche sur le web devrait vous y amener rapidement. Site web de htop Code web : 175372
partir de l, il est indispensable de savoir lire l'anglais. Recherchez sur le site la section Downloads , puis, sur la page des tlchargaments, recherchez les sources. Vous devriez nalement arriver sur une page qui vous propose de tlcharger les dernires sources du programme : Tlcharger les sources de htop Code web : 954263 Vous allez tlcharger une archive compresse .tar.gz. Vous connaissez la commande pour extraire ce type d'archive, alors allez-y !
5. Instructions qui sont, bien souvent, en anglais. 6. Notez qu'on le retrouve dans les dpts via apt-get, mais nous allons tout de mme essayer de le compiler manuellement pour nous entraner.
424
tr zxvf htopEHFVFQFtrFgz
On peut maintenant se rendre dans le dossier o les chiers sources ont t dcompresss :
d htopEHFVFQ
Si vous listez le contenu de ce rpertoire, vous allez tre surpris : il y a beaucoup de chiers ! Heureusement, vous n'avez pas vous en proccuper. Pour le moment, un seul programme nous intresse : configure. Excutez-le comme suit :
FGonfigure
configure est un programme qui analyse votre ordinateur et qui vrie si tous les
outils ncessaires la compilation du logiciel que vous souhaitez installer sont bien prsents. Son excution peut prendre du temps car il eectue de nombreux tests :
6 FGonfigure heking for fhEomptile instllFFF GusrGinGinstll E heking whether uild environment is sneFFF yes heking for thredEsfe mkdir EpFFF GinGmkdir Ep heking for gwkFFF gwk heking whether mke sets 6@weuiAFFF yes heking for gFFF g heking for g ompiler defult output file nmeFFF Fout heking whether the g ompiler worksFFF yes heking whether we re ross ompilingFFF no heking for suffix of exeutlesFFF heking for suffix of ojet filesFFF o heking whether we re using the qx g ompilerFFF yes heking whether g epts EgFFF yes heking for g option to ept sy gVWFFF none needed heking for style of inlude used y mkeFFF qx heking dependeny style of gFFF gQ FFF
Un des premiers lments qu'il va vrier est la prsence du compilateur (checking for gcc...) que vous avez normalement d installer un peu plus tt avec le paquet build-essential. Patientez le temps de l'excution de configure. Celui-ci va vous indiquer si tout est prt pour une compilation ou non. Malheureusement, il arrivera frquemment que configure ache une erreur en raison d'un manque de dpendances. Dans notre cas, il devrait acher une erreur comme celle-ci : 425
CHAPITRE 26.
heking for sysGtimeFhFFF yes heking for unistdFhFFF @hedA yes heking ursesFh usilityFFF no heking ursesFh preseneFFF no heking for ursesFhFFF no onfigureX errorX missing hedersX ursesFh
L'erreur (sur la dernire ligne) indique en anglais missing headers: curses.h . C'est l que les choses se corsent : il faut installer l'lment manquant, en l'occurrence ces fameux headers de curses.h. Si vous n'tes pas programmeurs, vous n'avez probablement aucune ide de ce dont il s'agit. La technique la plus ecace consiste eectuer une recherche de la ligne d'erreur sur le web, accompagne de prfrence du mot-cl ubuntu . Lancez donc une recherche de congure : error : missing headers : curses.h ubuntu . Une recherche de ces mots cls devrait gnralement vous acher des rsultats qui vous dirigeront bien souvent sur des forums anglophones. Recherche de l'erreur Code web : 550448 Il faut alors faire preuve de patience et ne pas avoir peur de lire un peu d'anglais. ;-) L'information chercher est le nom du paquet manquant que vous devez installer. En lisant les forums, vous devriez nir par trouver le nom du paquet que vous recherchez : libncurses5-dev. En l'occurrence, il sut d'installer ce paquet via apt-get pour ne plus avoir l'erreur indique dans configure.
sudo ptEget instll linursesSEdev
Une fois le paquet install, relancez configure et croisez les doigts 7 pour que l'erreur disparaisse :
FGonfigure
Si configure n'ache plus la mme erreur, vous avez gagn (pour le moment). Il reste maintenant deux possibilits : soit vous avez une nouvelle erreur et vous devrez la rsoudre de la mme manire : en eectuant une recherche sur l'internet pour comprendre ce qui ne va pas. Le plus souvent, il sura d'installer le paquet manquant avec apt-get ; soit vous n'avez pas d'erreur et configure parvient jusqu' son terme. Victoire ! Si tout va bien, configure n'achera pas d'erreur. Vous devriez voir s'acher des lignes similaires celles-ci :
7. Cela n'a pas t scientiquement prouv, mais croiser les doigts peut augmenter vos chances de russite. La magie vaudou est aussi un bon moyen de se sortir des situations compliques, mais elle est rserver aux utilisateurs expriments. ;-)
426
onfigureX reting FGonfigFsttus onfigFsttusX reting plpEIFIGwkefile onfigFsttusX reting plpEIFIGsrGwkefile onfigFsttusX reting wkefile onfigFsttusX reting htopFI onfigFsttusX reting onfigFh onfigFsttusX onfigFh is unhnged onfigFsttusX reting plpEIFIGsrGplponfigFh onfigFsttusX reting plpEIFIGsrGplpFh onfigFsttusX exeuting depfiles ommnds
Le programme est prt tre compil ! Rassurez-vous, le plus dur est derrire vous. :-) Il sut maintenant de lancer la compilation l'aide d'une commande toute simple :
mke
Durant la compilation, des lignes barbares s'acheront dans votre console. Vous ne devriez pas avoir vous en proccuper, tous les problmes ayant normalement t dtects auparavant par configure.
La compilation d'un programme peut prendre du temps ; tout dpend de la taille de celui-ci. Il est ainsi bien plus rapide et plus simple de compiler htop que Firefox par exemple.
Une fois la compilation termine, l'excutable devrait avoir t cr. Il ne reste plus qu' l'installer, c'est--dire le copier dans le bon rpertoire. L encore, vous n'avez pas vous poser beaucoup de questions. Excutez la commande suivante :
sudo mke instll
Il faut tre root pour cette opration (d'o le sudo) car le programme va tre copi dans des rpertoires systme. Une fois que cela est fait, le programme est install ! Nous pouvons prsent excuter htop en tapant le nom de la commande :
htop
Si vous souhaitez dsinstaller le programme, il sut d'excuter cette commande depuis le rpertoire o vous l'avez compil :
sudo mke uninstll
Vous pouvez sans problme supprimer le rpertoire contenant les chiers sources (celui depuis lequel vous avez compil). Toutefois, il ne sera alors plus possible de lancer la commande de dsinstallation.
427
CHAPITRE 26.
En rsum
La plupart des programmes peuvent tre installs facilement avec la commande apt-get. Certains programmes ne peuvent pas tre installs via apt-get car ils ne sont pas rfrencs dans les dpts d'Ubuntu. Dans ce cas, on peut rechercher sur le web un paquet .deb du programme, sous rserve qu'il existe. Si la solution prcdente choue, on n'a pas d'autre choix que de compiler le programme partir de ses sources. Cela consiste eectuer les oprations suivantes dans l'ordre : 1. tlcharger les sources du programme sur le web (souvent archives au format .tar.gz) ; 2. dcompresser l'archive (tar zxvf archive.tar.gz) ; 3. excuter ./configure et rsoudre les problmes ; 4. excuter make pour compiler ; 5. excuter sudo make install pour installer le programme.
428
Cinquime partie
Automatisez vos tches avec des scripts Bash
429
Chapitre
27
Dicult :
ans cette dernire partie, nous allons runir toutes les connaissances que nous avons acquises concernant les commandes utilises sous Linux. Nous allons les combiner et crer ce que l'on appelle des scripts shell. Le scripting shell est un minilangage de programmation intgr tous les systmes Linux et qui vous permet d'automatiser des tches rptitives. Il s'agit d'un lment trs puissant du systme que vous devez absolument connatre. Toutefois, pour programmer, il va vous falloir utiliser un diteur de texte digne de ce nom. Certes, vous connaissez dj Nano mais comme je vous l'ai dit ce dernier est trs basique. Nous l'avons utilis au dpart pour simplier, mais il est temps prsent de passer quelque chose de plus complet et de plus puissant : Vim (prononcez Vi aille me ).
431
CHAPITRE 27.
Installer Vim
Sous Linux, deux puissants diteurs de texte en console sont connatre. Vim : il s'agit d'une version amliore de l'un des plus anciens diteurs en console : Vi (prononcez les lettres en anglais Vi aille ). Vim (VI iMproved, version amliore de Vi) est largement rpandu et gnralement disponible par dfaut sur la plupart des OS bass sur Unix, comme Linux. Emacs : dvelopp par Richard Stallman, le fondateur du projet GNU dont je vous ai parl au dbut du livre, cet diteur concurrent a lui aussi bien des atouts. On le retrouve plus spciquement sous Linux mais il est rarement install par dfaut (un petit apt-get sut, toutefois). Il peut tre complt par toute une srie de plugins qui lui permettent de faire navigateur web, lecteur audio. . . Bref, c'est un peu un outil tout faire. Sachez qu'il est courant que les gens adoptent et dfendent bec et ongles l'un ou l'autre de ces diteurs. Choisir un diteur de texte sous Linux, c'est en fait un peu comme choisir une religion 1 .
432
INSTALLER VIM
Si vous ne l'avez pas, installez le paquet vim-common. . . mais normalement il devrait dj tre prsent sur votre distribution. En fait, Vimtutor lance simplement Vim en ouvrant un chier d'aide prdni. Cette introduction Vim est d'ailleurs en franais et accessible tout le monde, aussi je vous invite l'essayer et la lire en complment de ce qui suit.
433
CHAPITRE 27.
Petit aperu :
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa a f i e n v e n u e dns le u t o r i e l de s w E ersion IFSFfrFP aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa im est un diteur trs puissnt qui trop de ommndes pour pouvoir toutes les expliquer dns un ours omme eluiEiD qui est onu pour en drire suffismment fin de vous permettre d9utiliser simplement imF ve temps requis pour suivre e ours est d9environ PS QH minutesD selon le temps que vous psserez exprimenterF ves ommndes utilises dns les leons modifieront le texteF pites une opie de e fihier fin de vous entrner dessus @si vous vez ln 4vimtutor4 ei est dj une opieAF sl est importnt de grder en tte que e ours est onu pour pprendre pr l prtiqueF gel signifie que vous devez exuter les ommndes pour les pprendre orretementF i vous vous ontentez de lire le texteD vous oulierez les ommndes 3 wintenntD vrifiez que votre lvier n9est e verouill en mjusulesD et ppuyez l touhe j le nomre de fois suffisnt pour que l leon IFI remplisse ompltement l9rnF ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
Il faut compter en gnral une bonne demi-heure pour suivre le Vimtutor. Cela vous fait une bonne petite introduction au logiciel, mais gardez bien entendu l'esprit que les possibilits sont bien plus grandes et que vous n'aurez pas tout vu l'issue de sa lecture.
Vim s'ouvre alors (gure 27.4). Vim est un programme un peu surprenant qui ne s'utilise pas comme la plupart des diteurs de texte que vous connaissez. Il m'a fallu un peu de temps pour m'y habituer et il vous en faudra aussi, mais le jeu en vaut la chandelle. 434
tout
Figure 27.1 Vim On a connu moins austre, mais c'est un diteur de texte, aprs
Si on ne vous explique rien, vous risquez d'tre un peu perdus. Pire, vous aurez mme du mal sortir de Vim 4 . Voil ce qu'il faut savoir. . . et qu'on aurait d m'expliquer ds le dpart, d'ailleurs. Vim possde trois modes de travail dirents. Mode interactif : c'est le mode par dfaut par lequel vous commencez. En lanant Vim, vous tes donc en mode interactif. Dans ce mode, vous ne pouvez pas crire de texte (oui, je sais, il s'agit d'un comble pour un diteur de texte !). N'essayez donc pas d'appuyer sur des lettres au hasard car vous risqueriez de faire n'importe quoi ! Le mode interactif est un mode puissant qui permet de se dplacer dans le texte, de supprimer une ligne, copier-coller du texte, rejoindre une ligne prcise, annuler ses actions, etc. Chaque action peut tre dclenche en appuyant sur une touche du clavier (par exemple, on appuie sur u pour annuler la dernire action). Mode insertion : celui-l, c'est celui que vous connaissez ! Vous tapez du texte et ce dernier s'insre l'endroit o se trouve le curseur. Pour entrer dans ce mode, il existe plusieurs possibilits. L'une des plus courantes est d'appuyer sur la touche i (insertion ). Pour en sortir, il faut appuyer sur la touche Echap. Mode commande : ce mode permet de lancer des commandes telles que quitter , enregistrer , etc. Vous pouvez aussi l'utiliser pour activer des options de Vim (comme la coloration syntaxique, l'achage du numro des lignes. . .). Vous pouvez mme envoyer des commandes au shell (la console) telles que ls, locate, cp, etc. Pour activer ce mode, vous devez tre en mode interactif et appuyer sur la touche deux points : . Vous validerez la commande avec la touche Entre et reviendrez alors au mode interactif.
4. Ne riez pas, a m'est arriv la premire fois !
435
CHAPITRE 27.
Je rsume. Vim possde trois modes (gure 27.2) : interactif, insertion et commande. Vous dmarrez en mode interactif. Le seul mode que vous connaissez et qui ne sera pas nouveau pour vous est le mode insertion. Les deux autres modes (interactif et commande) vont quelque peu vous surprendre.
Et pour ceux qui voudraient une interface graphique, sachez que Vim a t port sous Gnome sous le nom gVim . Vous pouvez donc l'installer 5 et le lancer : le fonctionnement est identique celui du Vim de la console. Il est mme disponible en version Windows (gure 27.3). . . si ce n'est pas beau, a ! Par dfaut, cette fentre ache des menus et une barre d'outils, comme un diteur de texte classique. Un habitu du Vim console aura bien entendu plutt tendance utiliser les raccourcis clavier, qui permettent de gagner du temps.
437
CHAPITRE 27.
L'ouverture de Vim
Pour le moment, si vous lancez Vim en tapant simplement la commande suivante sans aucun paramtre :
vim
. . . il s'ouvre sur un nouveau chier vide que vous avez dj vu (gure 27.4).
Figure 27.4 Vim (le texte d'introduction que vous voyez disparatra ds que vous
crirez les premiers caractres) Vous pouvez aussi ouvrir un chier en ajoutant son nom en paramtre :
vim nomdufihier
: insrer du texte
Nous allons partir d'un chier vide. Nous souhaitons commencer par entrer du texte (quoi de plus normal pour un diteur de texte, aprs tout ?). Appuyez sur i ( i minuscule). Vous basculez alors en mode insertion ; prsent, il vous est possible de taper du texte (gure 27.5). Notez le message -- INSERT -- en bas de l'cran, qui vous conrme que vous tes en mode insertion. 438
Le dplacement
h, j, k, l
En mode interactif, il est possible de dplacer le curseur au sein du texte. Pour cela, on utilise les touches : h : aller gauche ; j : aller en bas ; k : aller en haut ; l : aller droite.
CHAPITRE 27.
QUOIII ? C'est le comble ! On ne peut mme pas utiliser les ches du clavier pour se dplacer ? !
Si si, vous pouvez galement les utiliser : vous n'avez qu' essayer pour voir. D'ailleurs, en mode insertion, c'est la seule chose qui fonctionne.
0
Pour placer le curseur au tout dbut de la ligne, appuyez sur 0 en mode interactif. La touche Origine que vous avez peut-tre l'habitude d'utiliser fonctionne aussi. Cependant, retenez plutt qu'il faut utiliser 0, a vous sera utile par la suite. De mme, pour se rendre en n de ligne, appuyez sur la touche $. L encore, la touche Fin fonctionne elle aussi, mais essayez de prendre l'habitude d'utiliser $ ; ce sera payant, vous allez voir.
w
Avec w, vous pouvez vous dplacer de mot en mot dans le chier. C'est un autre moyen, parfois plus ecace et plus rapide, pour se dplacer au sein d'une ligne du chier.
:w
: enregistrer le chier
Pour enregistrer votre chier, vous devez tre au pralable en mode interactif (appuyez sur Echap pour vous en assurer). Appuyez ensuite sur la touche deux points : pour passer en mode commande, puis tapez w (write ) suivi du nom du chier. La commande doit s'acher en bas. Dans mon cas, j'ai donc tap :w monfichier 6 (gure 27.7). Appuyez ensuite sur la touche Entre pour valider. Le bas de l'cran doit indiquer que le chier a t crit (written ) :
4monfihier4 xew RvD IVSg written RDIHIEWV ell
:q
: quitter
J'ai essay de quitter en ayant fait des modications aprs avoir enregistr et un message d'erreur s'ache en rouge : No write since last change .
Maintenant que vous avez enregistr, vous pouvez quitter Vim en tapant :q.
6. Notez que j'aurais tout aussi bien pu donner une extension .txt mon chier.
440
:wq
C'est la combinaison des deux commandes que nous venons de voir. Vous enregistrez et quittez immdiatement Vim lorsque vous tapez :wq.
Placez le curseur sur une lettre en mode interactif puis appuyez sur x pour l'eacer. Cela revient appuyer sur Suppr en mode insertion. On peut aller plus loin et eacer plusieurs lettres d'un coup. Pour cela, utilisez la formule suivante : 441
CHAPITRE 27.
(nombre)x
Par exemple, si vous tapez 4x (4 puis x), vous supprimerez les quatre prochaines lettres en partant du curseur.
Vous devez taper 4 puis x. Ne vous tonnez pas si rien ne s'ache l'cran lorsque vous tapez 4 : c'est normal. crivez la commande jusqu'au bout, cela fonctionnera.
d
De la mme manire, on utilise la touche d pour supprimer des mots et des lignes. Commenons par supprimer une ou plusieurs lignes.
dd
Appuyez deux fois sur d (dd) pour supprimer toute la ligne sur laquelle se trouve le curseur. Mieux : vous pouvez faire prcder cette instruction d'un nombre de lignes supprimer. Par exemple, si vous tapez 2dd, vous supprimerez deux lignes d'un coup.
Encore une fois, ne vous tonnez pas si juste aprs avoir tap 2 rien ne s'ache l'cran. L'information est garde en mmoire par Vim, mais l'action ne sera vraiment excute que lorsque vous aurez tap entirement 2dd.
Note importante : la ligne ainsi supprime est en fait coupe et place en mmoire. Elle peut tre colle, comme on le verra plus loin, avec la touche p.
dw
: supprimer un mot
Placez le curseur sur la premire lettre d'un mot. Tapez ensuite dw (delete word ) : cela supprime le mot complet ! Si le curseur est positionn au milieu du mot, vous ne supprimerez que les prochains caractres de celui-ci (jusqu' l'espace qui suit). Vous pouvez aussi supprimer les trois prochains mots en tapant 3dw. Notez que le 3 peut tre plac entre le d et le w ; cela revient au mme : d3w (qui peut se lire delete 3 words ).
d0
Vous souvenez-vous de 0 et de $ ? Je vous avais demand de les utiliser la place des touches Origine et Fin car nous en aurions nouveau besoin par la suite. Le moment est venu de s'en resservir. 442
En tapant d0, vous supprimez du curseur jusqu'au dbut de la ligne. En tapant d$, vous supprimez du curseur jusqu' la n de la ligne. Pratique !
yy
yy copie la ligne actuelle en mmoire. Cela fonctionne comme dd, qui lui la coupe . Vous pouvez aussi utiliser yw pour copier un mot, y$ pour copier du curseur jusqu' la
n de la ligne, etc.
: coller
Si vous avez coup du texte avec dd ou copi du texte avec yy (ou un de leurs quivalents) vous pouvez ensuite le coller avec la touche p.
Attention, retenez bien ceci : si vous avez copi une ligne en mmoire et que vous appuyez sur p, elle sera colle sur la ligne situe aprs le curseur. On est parfois surpris de voir o se colle le texte ; prenez donc le temps de vous y habituer.
Vous pouvez aussi coller plusieurs fois un texte en faisant prcder le p d'un nombre. Par exemple, 8p collera huit fois le texte en mmoire. Si je place mon curseur sur une ligne, que je tape yy puis 8p, je la collerai donc huit fois (gure 27.8) !
CHAPITRE 27.
Si vous avez fait une faute sur une lettre seulement, vous pouvez passer en mode remplacement. Placez le curseur sur la lettre remplacer. Tapez r suivi de la lettre que vous voulez mettre la place. Par exemple, rs remplace la lettre actuelle par un s . Si vous utilisez un R majuscule, vous basculerez cette fois dans le mode remplacement : vous pourrez alors remplacer plusieurs lettres la fois. Vous pouvez par exemple crire Rbonjour pour remplacer les caractres par bonjour . Pour revenir au mode interactif normal, appuyez sur Echap.
Pour annuler vos dernire modications, appuyez sur u (undo ). Si vous souhaitez annuler vos quatre dernires modications, appuyez sur 4u 7 . Pour rpter un changement (= annuler une annulation), appuyez sur Ctrl + R.
: sauter la ligne no X
Toutes les lignes d'un chier possdent un numro. La numrotation commence 1. Regardez bien en bas droite de Vim, vous devriez voir quelque chose comme 4,3. 4 correspond au numro de la ligne sur laquelle se trouve le curseur, et 3 au numro de la colonne (3e lettre de la ligne). Vous pouvez par exemple directement sauter la ligne no 7 en tapant 7G (attention, c'est un G majuscule, donc pensez laisser la touche Maj appuye). Pour sauter la dernire ligne, tapez simplement G. Pour revenir la premire ligne, tapez gg.
/ : rechercher un mot
Si vous tapez /, vous passez en mode recherche. Le curseur se place en bas de l'cran (vous indiquant que vous tes passs en mode commande). crivez ensuite le mot que
7. Vous commencez connatre la formule ; c'est toujours la mme :-D
444
vous recherchez, par exemple remplir : /remplir. Tapez ensuite sur Entre pour valider. Le curseur se place alors sur la prochaine occurrence de remplir dans le chier. Pour passer la prochaine occurrence du mot, plus bas dans le chier (s'il apparat plusieurs fois), appuyez sur n. Pour rechercher en arrire, appuyez sur N (Maj + n).
Si vous souhaitez ds le dpart lancer une recherche qui remonte vers le dbut du chier, utilisez ? au lieu de / pour lancer la recherche ; le fonctionnement reste le mme.
:s
Pour rechercher et remplacer du texte, c'est un peu plus compliqu. Il y a en eet plusieurs faons d'eectuer le remplacement. La plus simple faon d'eectuer une recherche consiste taper :s/ancien/nouveau pour rechercher ancien et le remplacer par nouveau . Le problme. . . c'est que cela ne remplacera que la premire occurrence d' ancien par nouveau . Voici toutes les variantes connatre : :s/ancien/nouveau : remplace la premire occurrence de la ligne o se trouve le curseur ; :s/ancien/nouveau/g : remplace toutes les occurrences de la ligne o se trouve le curseur ; :#,#s/ancien/nouveau/g : remplace toutes les occurrences dans les lignes no # # du chier ; :%s/ancien/nouveau/g : remplace toutes les occurrences dans tout le chier. C'est peut-tre ce que vous utiliserez le plus frquemment.
:r
: fusion de chiers
Avec :r, vous pouvez insrer un chier la position du curseur. Vous devez indiquer le nom du chier insrer, par exemple : :r autrefichier. L'autocompltion avec Tab fonctionne l aussi, donc pas besoin d'crire le nom du chier en entier !
CHAPITRE 27.
:sp
Le plus simple pour commencer est de dcouper l'cran horizontalement. Tapez la commande :sp pour scinder l'cran en deux, comme sur la gure 27.9.
Si le dcoupage horizontal par dfaut ne vous convient pas, sachez que vous pouvez aussi eectuer un dcoupage vertical avec :vsp (gure 27.10). Il est bien entendu possible de rpter plusieurs fois la commande et mme de combiner des dcoupages verticaux et horizontaux.
:!
Il est possible d'crire des commandes traditionnelles du shell directement dans Vim. Pour cela, commencez par taper :! suivi du nom de la commande. Essayez par exemple de taper :!ls. Vous acherez alors le contenu du dossier dans lequel vous vous trouvez ! Cette fonctionnalit est bien pratique pour eectuer quelques actions sans avoir quitter Vim.
CHAPITRE 27.
En activant ou dsactivant des options. La documentation complte des options est disponible en ligne. En installant des plugins. Voyez la page ocielle des plugins les plus tlchargs de Vim. Documentation des options Code web : 275604 Liste des plugins Code web : 863484 Nous n'allons pas passer en revue les plugins, mais il y a un certain nombre d'options intressantes qui valent le coup d'tre actives.
Il faut donc ajouter le prxe no devant le nom de l'option pour la dsactiver. Certaines options doivent tre prcises avec une valeur, comme ceci :
:set option=valeur
448
4 his line should not e removed s it ensures tht vrious options re 4 properly set to work with the imErelted pkges ville in heinF runtime3 deinFvim 4 nomment the next line to mke im more iEomptile 4 xyiX deinFvim sets 9noomptile9F etting 9omptile9 hnges numerous 4 optionsD so ny other options should e set epi setting 9omptile9F 4set omptile 4 imS nd lter versions support syntx highlightingF nommenting the next 4 line enles syntx highlighting y defultF 4syntx on 4 sf using drk kground within the editing re nd syntx highlighting 4 turn on this option s well
Les lignes commenant par " sont des commentaires. Je vous recommande de les lire, ils fournissent des informations utiles. Passons maintenant l'activation de quelques commandes bien utiles. Je vous recommande de travailler comme moi, avec le chier de conguration .vimrc, et d'activer les options qui vous plaisent en dcommentant les lignes concernes. Pour cela, la meilleure faon de procder est de se mettre en mode interactif, de se dplacer avec hjkl et d'appuyer sur x lorsque le curseur est sur un guillemet pour le supprimer et activer ainsi l'option.
syntax
Il s'agit clairement de la premire option activer : la coloration syntaxique. En fonction du type de chier que vous ouvrez, Vim colorera le texte. Vim supporte un trs trs grand nombre de langages de programmation : C, C++, Python, Java, Ruby, Bash, Perl, etc. 449
CHAPITRE 27.
Notez qu'il faut enregistrer, quitter et relancer Vim pour que le changement soit pris en compte. . . sauf bien sr si vous activez l'option la vole en tapant dans Vim :set syntax=ON.
background
Par dfaut, la coloration de Vim est plus adapte aux fonds clairs. Les commentaires, par exemple, sont crits en bleu fonc sur noir. . . ce qui n'est pas trs lisible. Si votre console est sur fond noir (comme chez moi), je vous recommande d'activer la prochaine option background et de la mettre dark.
set kgroundadrk
number
showcmd
Lorsque vous crivez une commande comme 2dd pour supprimer deux lignes, vous crivez l'aveugle. Vous ne voyez pas ce que vous avez crit. Contrairement Vi, Vim permet de pallier ce problme. . . encore faut-il activer l'option :
set showmd
450
Lors d'une recherche, si vous souhaitez que Vim ne fasse pas la dirence entre les majuscules et les minuscules, activez cette option :
set ignorese
mouse
Eh oui ! Mme en mode console, il est possible d'utiliser la souris. Commencez par activer le support de cette dernire :
set mousea
Dsormais, vous pourrez cliquer avec la souris sur une lettre pour y dplacer le curseur directement. Vous pourrez galement utiliser la molette de la souris pour vous dplacer dans le chier.
Il vous sera galement possible de slectionner du texte l'aide de la souris. Vous passerez alors en mode visuel. Dans ce mode, vous pouvez supprimer le texte slectionn (avec x, comme d'habitude), mais aussi mettre le texte tout en majuscules (U), minuscules (u), etc.
451
CHAPITRE 27.
En rsum
Vim est un diteur de texte trs puissant en console et qui ore plus de possibilits que Nano, que nous avons dcouvert plus tt dans cet ouvrage. Son grand concurrent est Emacs. Dans Vim, il existe trois modes : interactif, insertion et commande. Le mode par dfaut est le mode interactif. Il faut appuyer sur la touche i pour insrer du texte et sur la touche Echap pour revenir au mode interactif. On peut lancer des commandes en appuyant sur la touche deux points : depuis le mode interactif. Par exemple, :w enregistre le chier, :q quitte Vim et :wq eectue les deux la fois. Il existe de nombreux raccourcis connatre pour bien utiliser Vim ; il faut prendre le temps de les apprendre pour exploiter pleinement le logiciel. On peut modier le chier .vimrc pour activer certaines options de Vim, comme la coloration automatique du code.
452
Chapitre
28
Dicult :
ous venez d'apprendre utiliser un diteur de texte puissant comme Vim. Cela va vous tre particulirement utile pour les chapitres venir. Entrons maintenant dans le vif du sujet : la programmation shell. De quoi s'agit-il ? Imaginez un minilangage de programmation intgr Linux. Ce n'est pas un langage aussi complet que peuvent l'tre le C, le C++ ou le Java par exemple, mais cela permet d'automatiser la plupart de vos tches : sauvegarde des donnes, surveillance de la charge de votre machine, etc. On aurait trs bien pu faire tout cela en crant un programme en C par exemple. Le gros avantage du langage shell est d'tre totalement intgr Linux : il n'y a rien installer, rien compiler. Et surtout : vous avez trs peu de nouvelles choses apprendre. En eet, toutes les commandes que l'on utilise dans les scripts shell sont des commandes du systme que vous connaissez dj : ls, cut, grep, sort. . .
453
CHAPITRE 28.
On parlera beaucoup de shell dans cette section. De quoi s'agit-il exactement ? Nous rpondrons cette question en premier. Ensuite, nous raliserons notre tout premier script shell qui ache un message l'cran. . . et nous pourrons alors passer aux choses srieuses ds le chapitre suivant !
pauvre en fonctionnalits par rapport aux autres shells. Le bash (Bourne Again Shell ) est le shell par dfaut de la plupart des distributions Linux mais aussi celui du terminal de Mac OS X. Il y a fort parier que c'est celui que vous utilisez en ce moment sous Linux. Le bash est une amlioration du sh. Voici dans les grandes lignes comment ont volu les shells. Chacun hrite de la plupart des fonctionnalits de son anctre (gure 28.1).
CHAPITRE 28.
grer les processus (envoi en arrire-plan, mise en pause avec Ctrl + Z. . .) ; rediriger et chaner les commandes (les fameux symboles >, <, |, etc.) ; dnir des alias (par exemple ll signie chez moi ls -lArth). Bref, le shell fournit toutes les fonctionnalits de base pour pouvoir lancer des commandes. Souvenez-vous : nous avions modi un chier .bashrc dans un des premiers chapitres (celui o nous avons appris utiliser Nano, page 195 et suivantes). Le .bashrc est le chier de conguration du bash que Linux vous fait utiliser par dfaut. Chaque personne peut avoir son .bashrc pour personnaliser son invite de commandes, ses alias, etc.
Une fois install, il faut demander l'utiliser pour votre compte utilisateur. Pour cela, tapez :
6 hsh
chsh signie Change Shell. On vous demandera o se trouve le programme qui gre le shell. Vous devrez indiquer /bin/ksh pour ksh, /bin/sh pour sh, /bin/bash pour
bash, etc.
CHAPITRE 28.
il rend l'criture de scripts plus simple que sh ; il est plus rpandu que ksh et zsh sous Linux. En clair, le bash est un bon compromis entre sh (le plus compatible) et ksh / zsh (plus puissants).
Cration du chier
Commenons par crer un nouveau chier pour notre script. Le plus simple est d'ouvrir Vim en lui donnant le nom du nouveau chier crer :
6 vim essiFsh
J'ai donn ici l'extension .sh mon chier. On le fait souvent par convention pour indiquer que c'est un script shell, mais sachez que ce n'est pas une obligation. Certains scripts shell n'ont d'ailleurs pas d'extension du tout 1 .
Le # ! est appel le sha-bang. /bin/bash peut tre remplac par /bin/sh si vous souhaitez coder pour sh, /bin/ksh pour ksh, etc.
1. J'aurais donc pu appeler mon script essai tout court.
458
Bien que non indispensable, cette ligne permet de s'assurer que le script est bien excut avec le bon shell. En l'absence de cette ligne, c'est le shell de l'utilisateur qui sera charg. Cela pose un problme : si votre script est crit pour bash et que la personne qui l'excute utilise ksh, il y a de fortes chances pour que le script ne fonctionne pas correctement ! La ligne du sha-bang permet donc de charger le bon shell avant l'excution du script. partir de maintenant, vous devrez la mettre au tout dbut de chacun de vos scripts.
Excution de commandes
Aprs le sha-bang, nous pouvons commencer coder. Le principe est trs simple : il vous sut d'crire les commandes que vous souhaitez excuter. Ce sont les mmes que celles que vous tapiez dans l'invite de commandes ! ls : pour lister les chiers du rpertoire. cd : pour changer de rpertoire. mkdir : pour crer un rpertoire. grep : pour rechercher un mot. sort : pour trier des mots. etc. Bref, tout ce que vous avez appris, vous pouvez le rutiliser ici ! ;-) Allez, on va commencer par quelque chose de trs simple : un ls. On va donc crer un script bash qui va juste se contenter d'acher le contenu du dossier courant :
53GinGsh ls
C'est tout !
Les commentaires
Notez que vous pouvez aussi ajouter des commentaires dans votre script. Ce sont des lignes qui ne seront pas excutes mais qui permettent d'expliquer ce que fait votre script. Tous les commentaires commencent par un #. Par exemple :
53GinGsh 5 effihge de l liste des fihiers ls
Vous avez srement remarqu que la ligne du sha-bang commence aussi par un #. . . Oui, c'est un commentaire aussi, mais considrez que c'est un commentaire spcial qui a un sens. Il fait un peu exception. 459
CHAPITRE 28.
Ce qui nous intresse ici, ce sont les droits sur le chier : -rw-r--r--. Si vous vous souvenez un petit peu du chapitre sur les droits, vous devriez vous rendre compte que notre script peut tre lu par tout le monde (r), crit uniquement par nous (w), et n'est pas excutable (pas de x). Or, pour excuter un script, il faut que le chier ait le droit excutable . Le plus simple pour donner ce droit est d'crire :
6 hmod Cx essiFsh
Tout le monde a maintenant le droit d'excuter le script. Si vous voulez, vous pouvez limiter ce droit vous-mmes mais pour cela je vous invite revoir le cours sur les droits p. 189 car je ne vais pas me rpter. :-)
Excution du script
Le script s'excute maintenant comme n'importe quel programme, en tapant ./ devant le nom du script :
6 FGessiFsh essiFsh
2. Sous Vim, il sut de taper :wq ou encore :x.
460
Que fait le script ? Il fait juste un ls, donc il ache la liste des chiers prsents dans le rpertoire (ici, il y avait seulement essai.sh dans mon rpertoire). Bien entendu, ce script est inutile ; il tait plus simple de taper ls directement. Cependant, vous devez vous douter que l'on va pouvoir faire beaucoup mieux que a dans les prochains chapitres. Vous pouvez dj modier votre script pour qu'avant tout chose il vous donne galement le nom du rpertoire dans lequel vous vous trouvez :
53GinGsh pwd ls
Excution de dbogage
Plus tard, vous ferez probablement de gros scripts et risquerez de rencontrer des bugs. Il faut donc ds prsent que vous sachiez comment dboguer un script. Il faut l'excuter comme ceci :
6 sh Ex essiFsh
On appelle en fait directement le programme bash et on lui ajoute en paramtre un -x (pour lancer le mode dbogage) ainsi que le nom de notre script dboguer. Le shell ache alors le dtail de l'excution de notre script, ce qui peut nous aider retrouver la cause de nos erreurs :
6 sh Ex essiFsh C pwd GhomeGmteoPIGsripts C ls essiFsh
461
CHAPITRE 28.
Comment font les autres programmes pour pouvoir tre excuts depuis n'importe quel rpertoire sans ./ devant ?
Ils sont placs dans un des rpertoires du PATH. Le PATH est une variable systme qui indique o sont les programmes excutables sur votre ordinateur. Si vous tapez echo $PATH vous aurez la liste de ces rpertoires spciaux . Il vous sut donc de dplacer ou copier votre script dans un de ces rpertoires, comme /bin, /usr/bin ou /usr/local/bin (ou encore un autre rpertoire du PATH). Notez qu'il faut tre root pour pouvoir faire cela. Une fois que c'est fait, vous pourrez alors taper simplement essai.sh pour excuter votre programme et ce quel que soit le rpertoire dans lequel vous vous trouverez !
6 essiFsh GhomeGmteoPIGsripts essiFsh
En rsum
Contrairement aux apparences, il existe plusieurs environnements console dirents : ce sont les shells. Ce sont eux qui grent l'invite de commandes et ses fonctionnalits comme l'historique des commandes, la recherche Ctrl + R, l'autocompltion des commandes. . . Le shell utilis par dfaut sous Ubuntu est bash, mais il existe aussi ksh, zsh, etc. Il est possible d'automatiser une srie de commandes. On cre pour cela un chier contenant la liste des commandes excuter, appel script shell. On dit que l'on fait de la programmation shell. En fonction du shell utilis, on dispose de dirents outils pour crer son script shell. Nous utiliserons ici bash, donc notre chier de script doit commencer par la ligne #!/bin/bash. Dans le chier de script, il sut d'crire les commandes excuter les unes aprs les autres, chacune sur une ligne dirente. Pour excuter le script (et donc excuter la liste des commandes qu'il contient) il faut donner les droits d'excution au chier (chmod +x script.sh) et lancer l'excution du script avec la commande ./script.sh.
462
Chapitre
29
Dicult :
omme dans tous les langages de programmation, on trouve en bash ce que l'on appelle des variables. Elles nous permettent de stocker temporairement des informations en mmoire. C'est en fait la base de la programmation. Les variables en bash sont assez particulires. Il faut tre trs rigoureux lorsqu'on les utilise. Si vous avez fait du C ou d'autres langages de programmation, vous allez tre un peu surpris par leur mode de fonctionnement ; soyez donc attentifs. Et si vous n'avez jamais programm, soyez attentifs aussi. ;-)
463
CHAPITRE 29.
La premire ligne de tous nos scripts doit indiquer quel shell est utilis, comme nous l'avons appris plus tt. Commencez donc par crire :
53GinGsh
Cela indique que nous allons programmer en bash. Maintenant, dnissons une variable. Toute variable possde un nom et une valeur :
messgea9fonjour tout le monde9
Dans le cas prsent : la variable a pour nom message ; . . . et pour valeur Bonjour tout le monde.
Ne mettez pas d'espaces autour du symbole gal = ! Le bash est trs pointilleux sur de nombreux points, vitez par consquent de le vexer. Je vous signalerai systmatiquement les piges viter, car il y en a un certain nombre ! Si vous voulez insrer une apostrophe dans la valeur de la variable, il faut la faire prcder d'un antislash \. En eet, comme les apostrophes servent dlimiter le contenu, on est oblig d'utiliser un caractre d'chappement (c'est comme a que cela s'appelle) pour pouvoir vritablement insrer une apostrophe :
messgea9fonjour 9est moi9
Excutez-le pour voir ce qui se passe (aprs avoir modi les droits pour le rendre excutable, bien sr) :
6 FGvrilesFsh 6
464
ECHO
Il ne se passe rien !
echo
Avant de commencer parler de variables, il y a une commande que j'aimerais vous prsenter : echo. J'aurais pu en parler avant que l'on commence faire des scripts bash, mais vous n'en auriez pas vu l'utilit avant d'aborder ce chapitre. Son principe est trs simple : elle ache dans la console le message demand. Un exemple :
6 eho lut tout le monde lut tout le monde
Comme vous le voyez, c'est simple comme bonjour. Les guillemets ne sont pas requis.
Si vous voulez insrer des retours la ligne, il faudra activer le paramtre -e et utiliser le symbole \n : 465
CHAPITRE 29.
Comparez les lignes 3 et 4 : lorsque l'on dclare la variable la ligne 3, on ne doit pas mettre de $ devant. En revanche, lorsqu'on l'ache la ligne 4, on doit cette fois mettre un $ !
Rsultat :
fonjour tout le monde
Maintenant, supposons que l'on veuille acher la fois du texte et la variable. Nous serions tents d'crire :
53GinGsh messgea9fonjour tout le monde9 eho 9ve messge est X 6messge9
Le problme est que cela ne fonctionne pas comme on le souhaite car cela ache :
ve messge est X 6messge
Pour bien comprendre ce qui se passe, intressons-nous au fonctionnement de ce que l'on appelle les quotes .
Les quotes
Il est possible d'utiliser des quotes pour dlimiter un paramtre contenant des espaces. Il existe trois types de quotes : 466
ECHO
les apostrophes ' ' (simples quotes) ; les guillemets " " (doubles quotes) ; les accents graves ` ` (back quotes), qui s'insrent avec Alt Gr + 7 sur un clavier AZERTY franais. Selon le type de quotes que vous utilisez, la raction de bash ne sera pas la mme.
Avec de simples quotes, la variable n'est pas analyse et le $ est ach tel quel.
. . . a fonctionne ! Cette fois, la variable est analyse et son contenu ach. En fait, les doubles quotes demandent bash d'analyser le contenu du message. S'il trouve des symboles spciaux (comme des variables), il les interprte. Avec de simples quotes, le contenu tait ach tel quel.
467
CHAPITRE 29.
La commande pwd a t excute et son contenu insr dans la variable message ! Nous avons ensuite ach le contenu de la variable. Cela peut paratre un peu tordu, mais c'est rellement utile. Nous nous en resservirons dans les chapitres suivants.
read
Vous pouvez demander l'utilisateur de saisir du texte avec la commande read. Ce texte sera immdiatement stock dans une variable. La commande read propose plusieurs options intressantes. La faon la plus simple de l'utiliser est d'indiquer le nom de la variable dans laquelle le message saisi sera stock :
red nomvrile
Adaptons notre script pour qu'il nous demande notre nom puis qu'il nous l'ache :
53GinGsh red nom eho 4fonjour 6nom 34
Lorsque vous lancez ce script, rien ne s'ache, mais vous pouvez taper du texte (votre nom, par exemple) :
wthieu fonjour wthieu 3
Notez que la premire ligne correspond au texte que j'ai tap au clavier.
468
READ read
lit ce que vous tapez mot par mot (en considrant que les mots sont spars par des espaces). Il assigne chaque mot une variable dirente, d'o le fait que le nom et le prnom ont t correctement et respectivement assigns $nom et $prenom. Si vous rentrez plus de mots au clavier que vous n'avez prvu de variables pour en stocker, la dernire variable de la liste rcuprera tous les mots restants. En clair, si j'avais tap pour le programme prcdent Nebra Mathieu Cyril , la variable $prenom aurait eu pour valeur Mathieu Cyril .
-p
Bon : notre programme n'est pas trs clair et nous devrions acher un message pour que l'utilisateur sache quoi faire. Avec l'option -p de read, vous pouvez faire cela :
53GinGsh red Ep 9intrez votre nom X 9 nom eho 4fonjour 6nom 34
Notez que le message 'Entrez votre nom' a t entour de quotes. Si on ne l'avait pas fait, le bash aurait considr que chaque mot tait un paramtre dirent !
Rsultat :
intrez votre nom X wthieu fonjour wthieu 3
C'est mieux !
-n
Avec -n, vous pouvez au besoin couper au bout de X caractres si vous ne voulez pas que l'utilisateur insre un message trop long. Exemple :
53GinGsh red Ep 9intrez votre login @S rtres mxA X 9 En S nom eho 4fonjour 6nom 34 intrez votre login @S rtres mxA X mthifonjour mthi 3
469
CHAPITRE 29.
Notez que le bash coupe automatiquement au bout de 5 caractres sans que vous ayez besoin d'appuyer sur la touche Entre. Ce n'est pas trs esthtique du coup, parce que le message s'ache sur la mme ligne. Pour viter cela, vous pouvez faire un echo avec des \n, comme vous avez appris le faire plus tt :
53GinGsh red Ep 9intrez votre login @S rtres mxA X 9 En S nom eho Ee 4nfonjour 6nom 34 intrez votre login @S rtres mxA X mthi fonjour mthi 3
-t
Vous pouvez dnir un timeout avec -t, c'est--dire un nombre de secondes au bout duquel le read s'arrtera.
53GinGsh red Ep 9intrez le ode de dsmorge de l ome @vous vez S seondesA X 9 Et S ode eho Ee 4nfoum 34
-s
Probablement plus utile, le paramtre -s masque les caractres que vous saisissez. Cela vous servira notamment si vous souhaitez que l'utilisateur entre un mot de passe :
53GinGsh red Ep 9intrez votre mot de psse X 9 Es pss eho Ee 4nweri 3 te vis dire tout le monde que votre mot de psse est 6pss 3 XEA4 intrez votre mot de psse X weri 3 te vis dire tout le monde que votre mot de psse est supertopseretQV 3 XEA
Comme vous pouvez le constater, le mot de passe que j'ai entr ne s'ache pas lors de l'instruction read. 470
Les oprations utilisables sont : l'addition : + ; la soustraction : - ; la multiplication : * ; la division : / ; la puissance : ** ; le modulo 1 : %. Quelques exemples :
let let let let let 4 4 4 4 4 a a a a a S B Q4 5 6 a IS R BB P4 5 6 a IT @R u rrA V G P4 5 6 a R IH G Q4 5 6 a Q IH 7 Q4 5 6 a I
Une petite explication pour les deux dernires lignes : 10 / 3 = 3 car la division est entire (la commande ne renvoie pas de nombres dcimaux) ; 10 % 3 renvoie 1 car le reste de la division de 10 par 3 est 1. En eet, 3 rentre 3 fois dans 10 (a fait 9), et il reste 1 pour aller 10.
1. Renvoie le reste de la division entire.
471
CHAPITRE 29.
Notez qu'il est possible aussi de contracter les commandes, comme cela se fait en langage C. Ainsi :
let 4 a B Q4
. . . quivaut crire :
let 4 Ba Q4
Actuellement, les rsultats renvoys sont des nombres entiers et non des nombres dcimaux. Si vous voulez travailler avec des nombres dcimaux, renseignez-vous sur le fonctionnement de la commande bc.
Il y en a beaucoup. Certaines sont trs utiles, d'autres moins. Parmi celles que je peux vous commenter et qui peuvent s'avrer utiles, on trouve : SHELL : indique quel type de shell est en cours d'utilisation (sh, bash, ksh. . .) ; 472
PATH : une liste des rpertoires qui contiennent des excutables que vous souhaitez pouvoir lancer sans indiquer leur rpertoire. Nous en avons parl un peu plus tt. Si un programme se trouve dans un de ces dossiers, vous pourrez l'invoquer quel que soit le dossier dans lequel vous vous trouvez ; EDITOR : l'diteur de texte par dfaut qui s'ouvre lorsque cela est ncessaire ; HOME : la position de votre dossier home ; PWD : le dossier dans lequel vous vous trouvez ; OLDPWD : le dossier dans lequel vous vous trouviez auparavant.
Notez que les noms de ces variables sont, par convention, crits en majuscules.
Comment utiliser ces variables dans vos scripts ? C'est trs simple, il sut de les appeler par leur nom ! Exemple :
53GinGsh eho 4otre diteur pr dfut est 6ihsy4 otre diteur pr dfut est nno
Plus rarement, vous pourriez avoir besoin de dnir votre propre variable d'environnement. Pour cela, on utilise la commande export que vous avez pu voir dans votre .bashrc.
Le problme, c'est que nous n'avons toujours pas vu comment rcuprer ces paramtres dans notre script. Pourtant, c'est trs simple raliser ! En eet, des variables sont automatiquement cres : $# : contient le nombre de paramtres ; $0 : contient le nom du script excut (ici ./variables.sh) ; $1 : contient le premier paramtre ; 473
CHAPITRE 29.
Et si on utilise plus de neuf paramtres ? J'ai cru voir que les variables s'arrtaient $9. . .
L, a va un peu loin, mais a peut arriver. On peut imaginer un script qui accepte une liste de chiers en paramtre. Rien ne nous empcherait de lui envoyer quinze paramtres dans ce cas :
FGsriptFsh fihierI fihierP fihierQ fihierR FFF fihierIR fihierIS
En gnral, pour traiter autant de paramtres, on s'occupera d'eux un par un. . . On peut dcaler les paramtres dans les variables $1, $2, etc. l'aide de la commande shift. Reprenons notre script :
53GinGsh eho 4ve prmtre I est 6I4 shift eho 4ve prmtre I est mintennt 6I4 6 FGvrilesFsh prmI prmP prmQ ve prmtre I est prmI ve prmtre I est mintennt prmP
Comme vous le voyez, les paramtres ont t dcals : $1 correspond aprs le shift au second paramtre, $2 au troisime paramtre, etc. Bien sr, shift est gnralement utilis dans une boucle qui permet de traiter les paramtres un par un. Nous verrons d'ailleurs comment faire des boucles dans peu de temps. 474
LES TABLEAUX
Les tableaux
Le bash gre galement les variables tableaux . Ce sont des variables qui contiennent plusieurs cases, comme un tableau. Vous en aurez probablement besoin un jour ; voyons comment cela fonctionne. Pour dnir un tableau, on peut faire comme ceci :
tleua@9vleurH9 9vleurI9 9vleurP9A
Cela cre une variable tableau qui contient trois valeurs (valeur0, valeur1, valeur2). Pour accder une case du tableau, il faut utiliser la syntaxe suivante :
6{tleuP}
Les cases sont numrotes partir de 0 ! La premire case a donc le numro 0. Notez par ailleurs que pour acher le contenu d'une case du tableau, vous devez entourer votre variable d'accolades comme je l'ai fait pour ${tableau[2]}.
Vous pouvez aussi dnir manuellement le contenu d'une case :
tleuPa9vleurP9
Comme vous pouvez le constater, le tableau peut avoir autant de cases que vous le dsirez. La numrotation n'a pas besoin d'tre continue, vous pouvez sauter des cases sans aucun problme 2 .
Vous pouvez acher l'ensemble du contenu du tableau d'un seul coup en utilisant ${tableau[*]} :
2. La preuve, il n'y a pas de case no 3 ni de case no 4 dans mon script prcdent.
475
CHAPITRE 29.
53GinGsh tleua@9vleurH9 9vleurI9 9vleurP9A tleuSa9vleurS9 eho 6{tleuB} vleurH vleurI vleurP vleurS
En rsum
Comme dans la plupart des langages de programmation, on peut crer des variables en shell qui stockent temporairement des valeurs en mmoire. Une variable nomme variable est accessible en crivant $variable. La commande echo ache un texte ou le contenu d'une variable dans la console. read attend une saisie au clavier de la part de l'utilisateur et stocke le rsultat dans une variable. On peut eectuer des oprations mathmatiques sur des nombres l'aide de la commande let. Certaines variables sont accessibles partout, dans tous les scripts : ce sont les variables d'environnement. On peut les lister avec la commande env. Les paramtres envoys notre script (comme ./script -p) sont transmis dans des variables numrotes : $1, $2, $3. . . Le nombre de paramtres envoys est indiqu dans la variable $#.
476
Chapitre
30
Dicult :
Les conditions
a prise de dcision est un lment indispensable dans tout programme. Si on ne pouvait pas dcider quoi faire, le programme ferait toujours la mme chose. . . ce qui serait bien ennuyeux. Les branchements conditionnels (que nous abrgerons conditions ) constituent un moyen de dire dans notre script SI cette variable vaut tant, ALORS fais ceci, SINON fais cela . Si vous connaissez dj un autre langage de programmation, cela doit vous tre familier. Sinon, ne vous en faites pas, vous allez trs vite comprendre le concept.
477
CHAPITRE 30.
LES CONDITIONS
if
Si
Les conditions ont la forme suivante :
SI test_de_variable ALORS ------> effectuer_une_action FIN SI
Bien entendu, ce n'est pas du bash. Il s'agit juste d'un schma pour vous montrer quelle est la forme d'une condition. La syntaxe en bash est la suivante :
if test then eho 4g9est vri4 fi
Le mot fi (if l'envers !) la n indique que le if s'arrte l. Tout ce qui est entre le then et le fi sera excut uniquement si le test est vri.
Vous noterez c'est trs important qu'il y a des espaces l'intrieur des crochets. On ne doit pas crire [test] mais [ test ] ! Il existe une autre faon d'crire le if : en plaant le then sur la mme ligne. Dans ce cas, il ne faut pas oublier de rajouter un point-virgule aprs les crochets :
if test Y then eho 4g9est vri4 fi
la place du mot test, il faut indiquer votre test. C'est cet endroit que vous testerez la valeur d'une variable, par exemple. Ici, nous allons voir un cas simple o nous testons la valeur d'une chane de caractres, puis nous apprendrons faire des tests plus compliqus un peu plus loin dans le chapitre. Faisons quelques tests sur un script que nous appellerons conditions.sh :
53GinGsh
478
IF
noma4fruno4 if 6nom a 4fruno4 then eho 4lut fruno 34 fi
Copier ce code Code web : 665574 Comme $nom est bien gal Bruno , ce script achera :
lut fruno 3
Essayez de changer le test : si vous n'crivez pas prcisment Bruno , le if ne sera pas excut et votre script n'achera donc rien. Notez aussi que vous pouvez tester deux variables la fois dans le if :
53GinGsh nomIa4fruno4 nomPa4wrel4 if 6nomI a 6nomP then eho 4lut les jumeux 34 fi
Comme ici $nom1 est dirent de $nom2, le contenu du if ne sera pas excut. Le script n'achera donc rien.
Sinon
Si vous souhaitez faire quelque chose de particulier quand la condition n'est pas remplie, vous pouvez rajouter un else qui signie sinon . En franais, cela s'crirait comme ceci :
SI test_de_variable ALORS ------> effectuer_une_action SINON ------> effectuer_une_action FIN SI if test then
479
CHAPITRE 30.
LES CONDITIONS
else fi
Bon : comme la variable vaut toujours la mme chose, le else ne sera jamais excut, ce n'est pas rigolo. Je vous propose plutt de vous baser sur le premier paramtre ($1) envoy au script :
53GinGsh if 6I a 4fruno4 then eho 4lut fruno 34 else eho 4t9te onnis psD ouste 34 fi
Copier ce code Code web : 318546 Testez maintenant votre script en lui donnant un paramtre :
6 FGonditionsFsh fruno lut fruno 3
Notez que le script plante si vous oubliez de l'appeler avec un paramtre. Pour bien faire, il faudrait d'abord vrier dans un if s'il y a au moins un paramtre. Nous apprendrons faire cela plus loin.
480
IF
Sinon si
Il existe aussi le mot cl elif, abrviation de else if , qui signie sinon si . Sa forme ressemble ceci :
SI test_de_variable ALORS ------> effectuer_une_action SINON SI autre_test ALORS ------> effectuer_une_action SINON SI encore_un_autre_test ALORS ------> effectuer_une_action SINON ------> effectuer_une_action FIN SI
C'est un peu plus compliqu, n'est-ce pas ? Sachez que l'on peut mettre autant de sinon si que l'on veut ; l, j'en ai mis deux. En revanche, on ne peut mettre qu'un seul sinon , qui sera excut la n si aucune des conditions prcdentes n'est vrie. Bash va d'abord analyser le premier test. S'il est vri, il eectuera la premire action indique ; s'il ne l'est pas, il ira au premier sinon si , au second, etc., jusqu' trouver une condition qui soit vrie. Si aucune condition ne l'est, c'est le sinon qui sera lu. Bien ! Voyons comment cela s'crit en bash :
if test then eho 4ve premier test t vrifi4 elif utretest then eho 4ve seond test t vrifi4 elif enoreutretest then eho 4ve troisime test t vrifi4 else eho 4euun des tests prdents n9 t vrifi4 fi
On peut reprendre notre script prcdent et l'adapter pour utiliser des elif :
53GinGsh if 6I a 4fruno4 then
481
CHAPITRE 30.
LES CONDITIONS
eho 4lut fruno 34 elif 6I a 4wihel4 then eho 4fien le onjour wihel4 elif 6I a 4ten4 then eho 4r tenD v c4 else eho 4t9te onnis psD ouste 34 fi
Copier ce code Code web : 830083 Vous pouvez tester ce script ; encore une fois, n'oubliez pas d'envoyer un paramtre sinon il plantera, ce qui est normal.
Les tests
Voyons maintenant un peu quels sont les tests que nous pouvons faire. Pour l'instant, on a juste vri si deux chanes de caractres taient identiques, mais on peut faire beaucoup plus de choses que cela !
482
LES TESTS
else fi
6 FGonditionsFsh fruno fernrd ves P prmtres sont diffrents 3 6 FGonditionsFsh fruno fruno ves P prmtres sont identiques 3
On peut aussi vrier si le paramtre existe avec -z (vrie si la chane est vide). En eet, si une variable n'est pas dnie, elle est considre comme vide par bash. On peut donc par exemple s'assurer que $1 existe en faisant comme suit :
53GinGsh if Ez 6I then eho 4s de prmtre4 else eho 4rmtre prsent4 fi 6 FGonditionsFsh s de prmtre 6 FGonditionsFsh prm rmtre prsent
483
CHAPITRE 30.
LES CONDITIONS
$chaine1 = $chaine2
Condition Signication
Vrie si les deux chanes sont identiques. Notez que bash est sensible la casse : b est donc dirent de B . Il est aussi possible d'crire == pour les habitus du langage C. Vrie si les deux chanes sont direntes. Vrie si la chane est vide. Vrie si la chane est non vide.
$num1 -eq $num2 $num1 -ne $num2 $num1 -lt $num2 $num1 -le $num2 $num1 -gt $num2 $num1 -ge $num2
Condition Signication
Vrie si les nombres sont gaux (equal ). ne pas confondre avec le = qui, lui, compare deux chanes de caractres. Vrie si les nombres sont dirents (non equal ). Encore une fois, ne confondez pas avec != qui est cens tre utilis sur des chanes de caractres. Vrie si num1 est infrieur ( < ) num2 (lower than ). Vrie si num1 est infrieur ou gal ( <= ) num2 (lower or equal ). Vrie si num1 est suprieur ( > ) num2 (greater than ). Vrie si num1 est suprieur ou gal ( >= ) num2 (greater or equal ).
484
LES TESTS
6 FGonditionsFsh PQ ous vez envoy PH ou plus 6 FGonditionsFsh II ous vez envoy moins de PH
Condition Signication
Vrie si le chier existe. Vrie si le chier est un rpertoire. N'oubliez pas que sous Linux, tout est considr comme un chier, mme un rpertoire ! Vrie si le chier est un. . . chier. Un vrai chier cette fois, pas un dossier. Vrie si le chier est un lien symbolique (raccourci). Vrie si le chier est lisible (r). Vrie si le chier est modiable (w). Vrie si le chier est excutable (x). Vrie si fichier1 est plus rcent que fichier2 (newer than ). Vrie si fichier1 est plus vieux que fichier2 (older than ).
485
CHAPITRE 30.
LES CONDITIONS
intrez un rpertoire X Ghome fienD vous vez ompris e que j9i dit 3 intrez un rpertoire X rienvoirFtxt ous n9vez rien omprisFFF
Notez que bash vrie au pralable que le rpertoire existe bel et bien.
Le test vrie deux choses : qu'il y a au moins un paramtre ( si $# est suprieur ou gal 1 ) ; que le premier paramtre est bien koala ( si $1 est gal koala ). Si ces deux conditions sont remplies, alors le message indiquant que l'on a trouv le bon mot de passe s'achera.
6 FGonditionsFsh kol frvo 3 ous onnissez le mot de psse
Notez que les tests sont eectus l'un aprs l'autre et seulement s'ils sont ncessaires. Bash vrie d'abord s'il y a au moins un paramtre. Si ce n'est pas le cas, il ne fera pas le second test puisque la condition ne sera de toute faon pas vrie.
486
CASE
Inverser un test
Il est possible d'inverser un test en utilisant la ngation. En bash, celle-ci est exprime par le point d'exclamation ! .
if 3 Ee fihier then eho 4ve fihier n9existe ps4 fi
case
On a vu tout l'heure un if un peu complexe qui faisait appel des elif et un else :
53GinGsh if 6I a 4fruno4 then eho 4lut fruno 34 elif 6I a 4wihel4 then eho 4fien le onjour wihel4 elif 6I a 4ten4 then eho 4r tenD v c4 else eho 4t9te onnis psD ouste 34 fi
Ce genre de gros if qui teste toujours la mme variable ne pose pas de problme mais n'est pas forcment trs facile lire pour le programmeur. la place, il est possible d'utiliser l'instruction case si nous voulons. Le rle de case est de tester la valeur d'une mme variable, mais de manire plus concise et lisible. Voyons comment on crirait la condition prcdente avec un case :
53GinGsh se 6I in 4fruno4A eho 4lut fruno 34 YY 4wihel4A
487
CHAPITRE 30.
LES CONDITIONS
4ten4A BA es
eho 4fien le onjour wihel4 YY eho 4r tenD v c4 YY eho 4t9te onnis psD ouste 34 YY
Copier ce code Code web : 870602 Cela fait beaucoup de nouveauts d'un coup. Analysons la structure du case !
se 6I in
Tout d'abord, on indique que l'on veut tester la valeur de la variable $1. Bien entendu, vous pouvez remplacer $1 par n'importe quelle variable que vous dsirez tester.
4fruno4A
L, on teste une valeur. Cela signie Si $1 est gal Bruno . Notez que l'on peut aussi utiliser une toile comme joker : B* acceptera tous les mots qui commencent par un B majuscule. Si la condition est vrie, tout ce qui suit est excut jusqu'au prochain double pointvirgule :
YY
Important, il ne faut pas l'oublier : le double point-virgule dit bash d'arrter l la lecture du case. Il saute donc la ligne qui suit le esac signalant la n du case.
BA
C'est en fait le else du case. Si aucun des tests prcdents n'a t vri, c'est alors cette section qui sera lue.
es
Marque la n du case (esac, c'est case l'envers !). Nous pouvons aussi faire des ou dans un case. Dans ce cas, petit pige, il ne faut pas mettre deux || mais un seul ! Exemple : 488
CASE
53GinGsh
se 6I in 4ghien4 | 4ght4 | 4ouris4A eho 4g9est un mmmifre4 YY 4woineu4 | 4igeon4A eho 4g9est un oiseu4 YY BA eho 4te ne sis ps e que 9est4 YY es
En rsum
On eectue des tests dans ses programmes grce aux if, elif, else, fi. On peut comparer deux chanes de caractres entre elles, mais aussi des nombres. On peut galement eectuer des tests sur des chiers : est-ce que celui-ci existe ? Est-il excutable ? Etc. Au besoin, il est possible de combiner plusieurs tests la fois avec les symboles && (ET) et || (OU). Le symbole ! (point d'exclamation) exprime la ngation dans une condition. Lorsque l'on eectue beaucoup de tests sur une mme variable, il est parfois plus pratique d'utiliser un bloc case in... esac plutt qu'un bloc if... fi.
489
CHAPITRE 30.
LES CONDITIONS
490
Chapitre
31
Dicult :
Les boucles
ous allons dcouvrir dans ce chapitre un autre lment de base de tous les langages : les boucles. Ces structures permettent de rpter autant de fois que ncessaire une partie du code. En bash, on n'y chappe pas ! Les consignes sont les mmes que pour le chapitre sur les conditions : il faut tre vigilant sur la syntaxe. Une espace de trop ou de moins, l'oubli d'un caractre spcial et plus rien ne fonctionne. Soyez donc trs rigoureux lorsque vous codez ! Si vous suivez cette simple rgle, vous n'aurez pas de problmes.
491
CHAPITRE 31.
LES BOUCLES
while
Le type de boucle que l'on rencontre le plus couramment en bash est while. Le principe est de faire un code qui ressemble ceci :
ex i test pesi EEEEEEb effetuerunetion igywwixgi
Il est aussi possible, comme pour le if, d'assembler les deux premires lignes en une, condition de mettre un point-virgule :
while test Y do eho 9etion en oule9 done
On va demander l'utilisateur de dire oui et rpter cette action tant qu'il n'a pas fait ce que l'on voulait. Nous allons crer un script boucles.sh pour l'occasion :
53GinGsh while Ez 6reponse || 6reponse 3a 9oui9 do red Ep 9hites oui X 9 reponse done
1. Est-ce que $reponse est vide ? 2. Est-ce que $reponse est dirent de oui ? Comme il s'agit d'un OU (||), tant que l'un des deux tests est vrai, on recommence la boucle. Cette dernire pourrait se traduire par : Tant que la rponse est vide ou que la rponse est dirente de oui . Nous sommes obligs de vrier d'abord si la variable n'est pas vide, car si elle l'est, le second test plante (essayez, vous verrez). Essayons ce script : 492
FOR
X X X X
Comme vous pouvez le voir, il ne s'arrte que lorsque l'on a tap oui !
Il existe aussi le mot cl until, qui est l'exact inverse de while. Il signie Jusqu' ce que . Remplacez juste while par until dans le code prcdent pour l'essayer.
for
La variable va prendre successivement les valeurs valeur1, valeur2, valeur3. La boucle va donc tre excute trois fois et la variable vaudra chaque fois une nouvelle valeur de la liste. En bash, la boucle for s'crit comme ceci :
53GinGsh for vrile in 9vleurI9 9vleurP9 9vleurQ9 do eho 4v vrile vut 6vrile4 done
493
CHAPITRE 31.
LES BOUCLES
Vous pouvez donc vous servir du for pour faire une boucle sur une liste de valeurs que vous dnissez :
53GinGsh for niml in 9hien9 9souris9 9moineu9 do eho 4eniml en ours d9nlyse X 6niml4 done eniml en ours d9nlyse X hien eniml en ours d9nlyse X souris eniml en ours d9nlyse X moineu
Toutefois, la liste de valeurs n'a pas besoin d'tre dnie directement dans le code. On peut utiliser une variable :
53GinGsh listefihiersals for fihier in 6listefihiers do eho 4pihier trouv X 6fihier4 done
On pourrait faire un code plus court sans passer par une variable $liste_fichiers en crivant : 494
FOR
Bien entendu, ici, on ne fait qu'acher le nom du chier, ce qui n'est ni trs amusant ni trs utile. On pourrait se servir de notre script pour renommer chacun des chiers du rpertoire actuel en leur ajoutant un suxe -old par exemple :
53GinGsh for fihier in ls do mv 6fihier 6fihierEold done
principe, qui va rajouter le suxe -old. . . uniquement aux chiers qui correspondent au paramtre envoy par l'utilisateur !
FGmultirenommgeFsh BFtxt
Si aucun paramtre n'est envoy, vous demanderez l'utilisateur de saisir le nom des chiers renommer avec read.
495
CHAPITRE 31.
LES BOUCLES
do done
eho 6i
Copier ce code Code web : 352257 Explication : seq gnre tous les nombres allant du premier paramtre au dernier paramtre, donc 1 2 3 4 5 6 7 8 9 10.
I P Q R S T U V W IH
Si vous le voulez, vous pouvez changer le pas et avancer de deux en deux par exemple. Dans ce cas, il faut crire seq 1 2 10 pour aller de 1 10 en avanant de deux en deux ; cela va donc gnrer les nombres 1 3 5 7 9.
En rsum
Pour excuter une srie de commandes plusieurs fois, on utilise des boucles. while permet de boucler tant qu'une condition est remplie. Le fonctionnement des conditions dans les boucles est le mme que celui des blocs if dcouverts dans le chapitre prcdent. for permet de boucler sur une srie de valeurs dnies. l'intrieur de la boucle, une variable prend successivement les valeurs indiques.
496
Chapitre
32
Dicult :
'intrt du bash ne commence se faire sentir que lorsque l'on code de vrais scripts, alors. . . il est grand temps de pratiquer ! Dans ce TP, vous allez devoir rutiliser un peu tout ce que vous avez appris jusqu'ici sur bash et sur Linux en gnral. N'oubliez pas que dans les scripts bash vous pouvez rutiliser toutes les commandes de la console que vous connaissez : ls, grep, cut, sort, les ux. . . allez-y, tous les coups sont permis. Vous risquez mme d'avoir lire le manuel pour trouver quelques paramtres ! Votre objectif est de crer une page web prsentant une galerie d'images en fonction des chiers prsents dans un dossier. Plus facile dire qu' faire, car vous allez voir qu'il y a l un vrai d. Bonne chance tous.
497
CHAPITRE 32.
Objectifs
Nous souhaitons raliser dans ce TP un gnrateur de galerie d'images en bash. Le script s'appellera galerie.sh. Pour sa premire version, il faudra le placer dans un dossier contenant des images ; il gnrera des miniatures partir de ces dernires et un chier HTML prsentant toutes les images du dossier. Concrtement, le script devra donc : crer une miniature de chaque image du dossier ; gnrer un chier HTML et y insrer ces miniatures ; faire un lien vers les images en taille originale.
Pour raliser ce script, il est recommand de connatre un petit peu le HTML. Vous avez un cours votre disposition sur le Site du Zro. C'est assez facile : ceux qui ne connaissent pas ne devraient pas y consacrer beaucoup de temps, d'autant plus qu'il sut de lire la premire partie seulement de ce cours pour faire ce TP.
Le rendu nal
La page web que vous devez arriver gnrer devrait ressembler la gure 32.1.
OBJECTIFS
aprs. ;-)
Copier ce code Code web : 913438 Vous pourrez rutiliser le dbut et la n de ce code source pour chaque chier HTML de galerie que vous crerez. Par contre, au milieu (les images <img /> et les liens <a>), il faudra adapter automatiquement le code en fonction des images prsentes dans le dossier. Vous acherez des miniatures sur la page et ferez un lien vers leur version agrandie.
499
CHAPITRE 32.
Les paramtres
Notre programme devra accepter un paramtre optionnel : le nom du chier HTML gnrer. S'il n'est pas prsent, on gnrera un chier galerie.html par dfaut.
Solution
L'heure est venue de passer la correction !
53GinGsh 5 rifition des prmtres 5 9ils sont sentsD on met une vleur pr dfut if Ez 6I then sortiea9glerieFhtml9 else sortiea6I fi 5 rprtion des fihiers et dossiers eho 99 b 6sortie if 3 Ee minitures then mkdir minitures fi 5 inEtte rwv eho 9`3hygi html fvsg 4EGGQgGGhh rwv IFH tritGGix4 4httpXGGwwwFwQForgGGxhtmlIGhhGxhtmlIEstritFdtd4b `html xmlnsa4httpXGGwwwFwQForgGIWWWGxhtml4 xmlXlnga4fr4 b `hedb `titlebw glerie`Gtitleb `met httpEequiva4gontentEype4 ontenta4textGhtmlY hrsetautfEV4 Gb `style typea4textGss4b img { orderXHY } `Gstyleb `Ghedb `odyb`pb9 bb 6sortie
500
AMLIORATIONS
5 qnrtion des minitures et de l pge for imge in ls BFpng BFjpg BFjpeg BFgif PbGdevGnull do onvert 6imge Ethumnil 9PHHxPHHb9 minituresG6imge eho 9` hrefa496imge94b`img sra4minituresG96imge94 lta44 Gb `Gb 9bb 6sortie done 5 ied de pge rwv eho 9`Gpb `Godyb `Ghtmlb9 bb 6sortie
Copier ce code Code web : 423338 Quelques commentaires sur le script : Il vrie d'abord si un paramtre est prsent. Si oui, il l'utilise comme nom de chier de sortie, sinon il utilise galerie.html. On doit crer un chier vide pour galerie.html. Normalement, on peut faire a avec touch, mais si le chier existe dj, on veut le vider. On choisit donc de faire un echo vide dans ce chier pour le vider. On cre le dossier qui accueillera les images miniatures s'il n'existe pas. On crit l'en-tte HTML dans le chier. On fait une boucle sur tous les chiers de type image (*.png, *.jpg, etc.) qui existent dans le dossier. Pour chacun d'eux, on cre une miniature d'une taille maximale de 200 x 200 pixels dans le sous-dossier miniatures. Le petit symbole > permet, comme indiqu dans la documentation du programme, de ne pas gnrer de miniature inutilement si l'image est de base plus petite que la taille des miniatures. On crit dans la page web la balise qui achera l'image et on fait un lien vers la version agrandie. Enn, on termine la page HTML en fermant les balises. Je tiens rappeler qu'il n'y a pas une seule faon de raliser ce script mais plusieurs. Je vous ai prsent la mienne et, bien qu'elle fonctionne, je vous prviens que l'on peut largement l'amliorer. Je vous propose d'ailleurs des pistes pour amliorer ce script.
Amliorations
Comme je le disais plus tt, le script que je vous ai propos de faire est minimal. Le but tait d'avoir raliser un script accessible tous et qui produise un rsultat intressant. Si vous voulez l'amliorer, les pistes ne manquent pas. En voici quelques-unes. Amliorer le design de la galerie avec un peu de CSS. 501
CHAPITRE 32.
Permettre de choisir le dossier contenant les images dont on veut gnrer une galerie. Actuellement, il faut que galerie.sh soit dans le bon dossier pour que cela fonctionne ! Utiliser un paramtre pour dnir la taille des miniatures gnrer. Acher le nom de l'image sous chaque image. Acher d'autres informations, comme les dimensions de l'image originale, sous chaque miniature. Il faudra faire appel l'outil convert pour obtenir ces informations. Acher la date de dernire modication sous chaque image. Pour certaines de ces amliorations, il faudra vous renseigner dans le manuel voire poser des questions sur les forums. Ne vous arrtez pas en si bon chemin ! Cherchez, cherchez et cherchez encore ! Vous allez vous habituer faire des recherches et vous deviendrez ainsi beaucoup plus autonomes. :-)
502
Index
alias . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209 apropos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 242 apt-cache search . . . . . . . . . . . . . . . . . . .224 apt-get autoremove . . . . . . . . . . . . . . . . 228 apt-get install . . . . . . . . . . . . . . . . . . . . 225 apt-get update . . . . . . . . . . . . . . . . . . . . . 222 apt-get upgrade . . . . . . . . . . . . . . . . . . . . 229 archive. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .340 arrt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 309 at . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 327 autocompltion. . . . . . . . . . . . . . . . . .130, 150 bash . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 454 .bashrc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 207 bg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315 BIOS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 bzip2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 344
case . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 487 cat . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 157 cd . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 146
compltion . . . . . . . . . . . . . . . . . . . . . . 130, 150 configure . . . . . . . . . . . . . . . . . . . . . . . . . . . 425 console . . . . . . . . . . . . . . . . . . . . . . . . . . . 18, 107 accs distance . . . . . . . . . . . . . . . . . 352 conguration . . . . . . . . . . . . . . . . . . . . 207 cp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 167 crontab . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 331 cryptage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 356 asymtrique . . . . . . . . . . . . . . . . . . . . . 358 symtrique . . . . . . . . . . . . . . . . . . . . . . 356 cut . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 271
date . . . . . . . . . . . . . . . . . . . . . . . . . . . . 296, 326 .deb . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 422
charge . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 297 chemin absolu . . . . . . . . . . . . . . . . . . . . . . . . . . . 148 relatif . . . . . . . . . . . . . . . . . . . . . . . . . . . 148 chgrp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 188 chirement . . . . . . . . . . . . . . . . . voir cryptage chmod . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 189 chown . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 187
Debian . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 dfragmentation. . . . . . . . . . . . . . . . . . . . . . .42 delgroup . . . . . . . . . . . . . . . . . . . . . . . . . . . . 186 deluser . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 184 dpendance . . . . . . . . . . . . . . . . . . . . . . . . . . 214 dpt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 215 distribution . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 dossier . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137 changement . . . . . . . . . . . . . . . . . . . . . 146 copie . . . . . . . . . . . . . . . . . . . . . . . . . . . . 168 cration . . . . . . . . . . . . . . . . . . . . . . . . . 166 dplacement . . . . . . . . . . . . . . . . . . . . . 169 taille . . . . . . . . . . . . . . . . . . . . . . . . . . . . 151 droits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 189 du . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 151
503
INDEX
personnalisation . . . . . . . . . . . . . . . . . 207 IP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 402 F iptables . . . . . . . . . . . . . . . . . . . . . . . . . . . . 412 fg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315 ISO . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24 chier achage. . . . . . . . . . . . . . . . . . . . . . . . .156 J cach . . . . . . . . . . . . . . . . . . . . . . . . . . . . 142 jobs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315 copie . . . . . . . . . . . . . . . . . . . . . . . . . . . . 167 joker . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 168 copie en rseau . . . . . . . . . . . . . . . . . . 388 K dplacement . . . . . . . . . . . . . . . . . . . . . 169 droits . . . . . . . . . . . . . . . . . . . . . . . . . . . 189 KDE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20, 75 lien. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .173 kill . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 305 liste . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141 killall . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 308 renommage . . . . . . . . . . . . . . . . . . . . . . 169 ksh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 454 sauvegarde . . . . . . . . . . . . . . . . . . . . . . 394 L suppression . . . . . . . . . . . . . . . . . . . . . . 170 synchronisation . . . . . . . . . . . . . . . . . . 394 less . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 159 raccourcis . . . . . . . . . . . . . . . . . . . . . . . 160 systme de . . . . . . . . . . . . . . . . . . . . . . . 48 tlchargement . . . . . . . . . . . . . . . . . . 386 lien physique . . . . . . . . . . . . . . . . . . . . . . . . 175 find . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 249 symbolique . . . . . . . . . . . . . . . . . . . . . . 176 rewall . . . . . . . . . . . . . . . . . . . . . voir pare-feu ux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 277 ligne de commande. . . . . . . . . . . . . . . . . . .107 for . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 493 ln . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 ftp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 390 locate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 248 log . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156 G login . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 gestionnaire de bureau . . . . . . . . . . . . . . . . 19 ls . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141 Gnome . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20, 63 M GNU . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9 grep . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 260 make . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 427 man . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232 groupe ajout . . . . . . . . . . . . . . . . . . . . . . . . . . . . 185 manuel. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .232 suppression . . . . . . . . . . . . . . . . . . . . . . 186 mkdir . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 166 GRUB. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .6, 61 more . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 159 gzip . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 344 mot de passe . . . . . . . . . . . . . . . . . . . . . . . . . 184 mv . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 169
image CD . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
INDEX
tlchargement . . . . . . . . . . . . . . . . . . . . . . . 386 telnet . . . . . . . . . . . . . . . . . . . . . . . . . . . 118, 353 terminal . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 112 top . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 303 R raccourcis (liste de) . . . . . . . . . . . . . . . . . . 133 touch . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 165 racine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 136 tty . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111, 114 read . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 468 U reboot . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 309 Ubuntu. . . . . . . . . . . . . . . . . . . . . . . . . . . .15, 29 recherche uniq . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 270 approfondie . . . . . . . . . . . . . . . . . . . . . 249 unrar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 348 indexe . . . . . . . . . . . . . . . . . . . . . . . . . . 248 unzip . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 347 rapide . . . . . . . . . . . . . . . . . . . . . . . . . . . 248 updatedb . . . . . . . . . . . . . . . . . . . . . . . . . . . . 249 redmarrage . . . . . . . . . . . . . . . . . . . . . . . . . 309 uptime . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 297 redirection . . . . . . . . . . . . . . . . . . . . . . . . . . . 277 usermod . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 186 dans un chier . . . . . . . . . . . . . . . . . . 278 utilisateur des erreurs . . . . . . . . . . . . . . . . . . . . . . 282 ajout . . . . . . . . . . . . . . . . . . . . . . . . . . . . 182 rm . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 170 liste des connects . . . . . . . . . . . . . . . 298 root. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .180 modication . . . . . . . . . . . . . . . . . . . . . 186 rsync . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 394 suppression . . . . . . . . . . . . . . . . . . . . . . 184
scp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 388 variable . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 464 screen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 317 d'environnement. . . . . . . . . . . . . . . . .472
installation . . . . . . . . . . . . . . . . . . . . . . 225 mise jour . . . . . . . . . . . . . . . . . . . . . . 229 suppression . . . . . . . . . . . . . . . . . . . . . . 228 paramtre. . . . . . . . . . . . . . . . . . . . . . . . . . . .127 pare-feu. . . . . . . . . . . . . . . . . . . . . . . . . . . . . .412 partitionnement . . . . . . . . . . . . . . . . . . . . . . . 46 passe (mot de) . . . . . . . . . . . . . . . . . . . . . . . 184 passwd . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 184 PATH. . . . . . . . . . . . . . . . . . . . . . . . . . .462, 473 port . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 410 processus . . . . . . . . . . . . . . . . . . . . . . . . . . . . 299 arrt . . . . . . . . . . . . . . . . . . . . . . . 305, 308 arrire-plan. . . . . . . . . . . . . . . . . . . . . .312 liste . . . . . . . . . . . . . . . . . . . . . . . . 300, 303 .profile . . . . . . . . . . . . . . . . . . . . . . . . . . . . 211 programme ajout . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70 mise jour . . . . . . . . . . . . . . . . . . . . . . . 72 suppression . . . . . . . . . . . . . . . . . . . . . . . 70 protocole . . . . . . . . . . . . . . . . . . . . . . . . 117, 353 ps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 300 PuTTY . . . . . . . . . . . . . . . . . . . . . . . . . 116, 367 pwd . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139
excution . . . . . . . . . . . . . . . . . . . . . . . . 460 paramtre . . . . . . . . . . . . . . . . . . . . . . . 473 sftp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 393 sh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 454 shell . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 454 script. . . . . . . . . . . . . . . . . . . . . . . . . . . .458 sleep . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 330 sort . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 265 SSH. . . . . . . . . . . . . . . . . . . . . . . . . . . . .116, 351 agent . . . . . . . . . . . . . . . . . . . . . . . . . . . . 375 cl . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 371 connexion . . . . . . . . . . . . . . . . . . . . . . . 365 serveur . . . . . . . . . . . . . . . . . . . . . . . . . . 364 ssh-copy-id . . . . . . . . . . . . . . . . . . . . . . . . .374 sudo . . . . . . . . . . . . . . . . . . . . . . . . . . . . 180, 181 synopsis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235 systme d'exploitation . . . . . . . . . . . . . . . . . . 4
tail . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 163 tar . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 340
505
INDEX
conguration . . . . . . . . . . . . . . . . . . . . 447 enregistrement . . . . . . . . . . . . . . . . . . 440 modes . . . . . . . . . . . . . . . . . . . . . . . . . . . 434 recherche . . . . . . . . . . . . . . . . . . . . . . . . 444 sortie . . . . . . . . . . . . . . . . . . . . . . . . . . . . 440 split . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 445 VirtualBox . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88 virtualisation. . . . . . . . . . . . . . . . . . . . . . . . . .88
w . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 296 wc . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 268 wget . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 386 which . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140 while . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 492 who . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 298 whois . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 405
X Z
506
Notes
Notes
Notes
Notes
Notes
Notes
Dpt lgal : septembre 2010 ISBN : 978-2-9535278-2-7 Code diteur : 978-2-9535278 Imprim en France Achev d'imprimer le 20 septembre 2010 sur les presses de Corlet Imprimeur (Cond-sur-Noireau) Numro imprimeur : 131159
Mentions lgales : Crdit photo Mathieu Nebra 4e de couverture : Xavier Granet - 2009 Conception couverture : Fan Jiyong Illustrations chapitres : Yannick Piault Les logos Gnome, KDE, Vim, Tux et Baby Tux sont sous licence GPL. http://www.gnu.org/licenses/gpl.html