logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

Vous n'êtes pas identifié(e).


L'icône rouge permet de télécharger chaque page du wiki visitée au format PDF et la grise au format ODT → ODT PDF Export

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Prochaine révision Les deux révisions suivantes
doc:programmation:shells:bash-les-differents-caracteres-speciaux [08/07/2014 06:08]
Hypathie [Shell BASH]
doc:programmation:shells:bash-les-differents-caracteres-speciaux [08/07/2014 08:53]
Hypathie [Quotes, apostrophe, guillemets et apostrophe inversée]
Ligne 33: Ligne 33:
 ===== Shell BASH ===== ===== Shell BASH =====
  
-Le shell (« coquille » en anglais) est également appelé interpréteur de commandes.+Le //shell// (« coquille » en anglais) est également appelé ​//interpréteur de commandes//.
  
-C'est une couche logicielle qui fournit une l'​interface utilisateur à système d'​exploitation. Il correspond à la couche la plus externe de ce dernier. ​ Il se présente sous la forme d'une interface en ligne de commande accessible depuis la console ou un terminal. L'​utilisateur lance des commandes sous forme d'une entrée texte exécutée ensuite par le shell.+>C'est une couche logicielle qui fournit une l'​interface utilisateur à système 
 +>d'​exploitation. ​ 
 +>Il correspond à la couche la plus externe de ce dernier.  ​ 
 +>Il se présente sous la forme d'une interface en ligne de commande accessible ​ 
 +>depuis la console ou un terminal. ​ 
 +>L'​utilisateur lance des commandes sous forme d'une entrée texte exécutée ensuite par le shell.
  
 <note tip>Le shell bash est l'un des shell utilisé sous gnu/linux. <note tip>Le shell bash est l'un des shell utilisé sous gnu/linux.
Ligne 41: Ligne 46:
   * http://​fr.wikipedia.org/​wiki/​Shell_Unix#​Historique_des_shell_Unix   * http://​fr.wikipedia.org/​wiki/​Shell_Unix#​Historique_des_shell_Unix
   * [[doc:​programmation:​shell:​shell#​introduction|le shell pour tous:​introduction]]   * [[doc:​programmation:​shell:​shell#​introduction|le shell pour tous:​introduction]]
 +
 +Quand on installe Debian Stable, le shell utilisateur par défaut est le shell Bash((alors que l'​interpréteur de commande par défaut pour les applications est dash)).
 </​note>​ </​note>​
  
-Quand on installe Debian Stable, le shell utilisateur par défaut est le shell **Bash**((alors que l'​interpréteur de commande par défaut pour les applications est **dash**)). 
  
 ==== Connaître votre shell utilisateur ==== ==== Connaître votre shell utilisateur ====
Ligne 50: Ligne 56:
 La commande ''​env''​ permet de lister les variables d'​environnement du contexte qui l'​exécute. La commande ''​env''​ permet de lister les variables d'​environnement du contexte qui l'​exécute.
 <code user>​env</​code>​ <code user>​env</​code>​
-Le retour est copieux ! Mais on trouve dans la liste : 
 <​code>​SHELL=/​bin/​bash</​code>​ <​code>​SHELL=/​bin/​bash</​code>​
-Ce qui signifie ​que le nom de l'​interpréteur de commande est bash.+>Le retour est copieux !  
 +>Mais on trouve dans la liste la ligne ci-dessus  
 +>​signifiant que le programme associé à la variable SHELL est le bash ; 
 +>​autrement dit, que le nom de l'​interpréteur de commande est bash. 
  
 === En affichant la variable SHELL === === En affichant la variable SHELL ===
Ligne 72: Ligne 81:
 Avant d'​aller plus loin : Avant d'​aller plus loin :
     *[[doc:​programmation:​shell:​shell|Le shell pour tous]]     *[[doc:​programmation:​shell:​shell|Le shell pour tous]]
-    * ET qui dit shell, dit commandes : [[:​doc:​systeme:​commandes:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !.]]  :-)+    * Et qui dit shell, dit commandes : [[:​doc:​systeme:​commandes:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !.]]  :-)
  
  
-==== Commandes internes, commandes ​externes ====+==== Commandes internes ​et externes ====
  
 Distinguons maintenant les commandes internes et les commandes externes au shell bash, commandes simples et les commandes composées. Distinguons maintenant les commandes internes et les commandes externes au shell bash, commandes simples et les commandes composées.
Ligne 110: Ligne 119:
 <code user>​which nom_commande</​code>​ <code user>​which nom_commande</​code>​
  
 +  * Le shell crée un //​[[atelier:​chantier:​bash-les-differents-caracteres-speciaux#​notion-de-processus|processus]]//​ pour exécuter une commande externe. Parmi les commandes externes que l'on trouve dans un système, il y a les exécutables ELF (ex. ls, mkdir, vi, sleep) et les fichiers de scripts (dont par exemple les scripts shell).\\ ​
 </​note>​ </​note>​
  
-==== Notion de processus ​==== +===Localisation des commandes===
- +
-Le shell crée un processus pour exécuter une commande externe. Parmi les commandes externes que l'on trouve dans un système, il y a les exécutables ELF (ex. ls, mkdir, vi, sleep) et les fichiers de scripts (dont par exemple les scripts shell).\\  +
-Un petit exemple pour illustrée la notion de processus : [[atelier:​chantier:​script-bash-variables-arguments-parametres?&#​exportation-de-la-valeur-d-une-variable|Exportation de la valeur d'une variable]].\\  +
-À voir aussi : [[https://​wiki.debian-facile.org/​atelier:​chantier:​script-bash-enchainement-de-commandes-et-etat-de-sortie#​notion-de-sous-shell|sous-shell]]+
  
 La localisation du code d'une commande externe doit être connu du shell pour qu'il puisse exécuter cette commande. A cette fin, bash utilise la valeur de sa variable prédéfinie PATH.  La localisation du code d'une commande externe doit être connu du shell pour qu'il puisse exécuter cette commande. A cette fin, bash utilise la valeur de sa variable prédéfinie PATH. 
Ligne 149: Ligne 155:
 Les commandes simples peuvent être des commandes internes ou des commandes externes. Les commandes simples peuvent être des commandes internes ou des commandes externes.
  
-  ​commandes internes par exemple : type, cd , echo , pwd, export ... +  ​commandes internes par exemple : type, cd , echo , pwd, export ... 
-  ​commandes externes par exemple : ls, mkdir, rm, rmdir, vi, cal ...+  ​commandes externes par exemple : ls, mkdir, rm, rmdir, vi, cal ...
  
   * Voici une liste non exhaustive des commandes simples, on y retrouve des commandes internes et externes :   * Voici une liste non exhaustive des commandes simples, on y retrouve des commandes internes et externes :
Ligne 158: Ligne 164:
 rm, rmdir, sed, setserial, sh, stty, su, sync, true, umount, uname. rm, rmdir, sed, setserial, sh, stty, su, sync, true, umount, uname.
 </​code>​ </​code>​
-(Consultez la documentation pour plus d'​information sur chacune d'​entre elles.)+>Consultez la documentation pour plus d'​information sur chacune d'​entre elles.
  
 === Les commandes composées par des mots clés === === Les commandes composées par des mots clés ===
Ligne 175: Ligne 181:
 </​note>​ </​note>​
  
 +==== Notion de processus ====
 +===Généralité===
 +De façon générale, la notion de processus recouvre tout le fonctionnement de\\ 
 +notre système GNU/linux et revoie à l'​utilisation du processeur de notre machine.\\ ​
 +L'​étude des processus mériterait à elle seule un livre entier, et dépasse largement celle du shell.\\ Voyons simplement dans les grandes lignes ce qu'est un processus, comment le shell permet de repérer un processus, et un exemple très simple d'​utilisation d'un processus.\\
 +
 +>Pour simplifier, on peut dire qu'un processus est un programme en cours d’exécution.
 +>Quand on lance une commande cela fait appel à un exécutable (un binaire ou un script), ​
 +>qui est dans la mémoire morte (dans le disque dur).
 +>Mais lorsqu'​un processus se lance, les instructions du programme passe en 
 +>​mémoire vive pour que le programme soit exécuté par le processeur.
 +
 +>Enfin un processeur ne peut exécuter qu'un processus à la fois, même si 
 +>du point de vue de l'​utilisateur,​ il semble que le système fait plusieurs ​
 +>choses en même temps. ​
 +>Cette impression est due à la rapidité de calcul du processeur, ​
 +>mais en réalité un programme essentiel au système, //​l'​ordonnanceur//, ​
 +>gère la priorité des différents processus placés en mémoire vive. 
 +
 +>Un processus peut donc être suspendu, relancé, mis en arrière plan (job), ​
 +>en premier plan, être un processus père ou enfant, être orphelin, et même devenir un zombie 8-).
 +>La gestion des processus nécessite donc que chaque processus possède un identifiant.
 +
 +>Enfin, une des particularités des systèmes GNU/Linux,
 +>​c'​est qu'un processus s'​exécute en fonction les droits accordés ​
 +>à l'​utilisateur qui l'a lancé. ​
 +>Ceci participe fortement à la sécurité du système. ​
 +
 +===Identifier un processus=== ​
 +>Un processus est identifié par un numéro unique que l'on appelle le PID (Process IDentifiant).
 +>Et chaque processus dispose d'un processus père que l'on appelle le PPID (Parent PID).
 +
 +>​Excepté le processus //init// qui a comme particularité d'​être le premier processus
 +>et de toujours utiliser le PID 1. 
 +>Ce processus démarre ensuite des processus noyaux et les premiers processus systèmes.
 +
 +Pour se faire plaisir en observant la hiérarchie des processus ;-) :
 +<code user>
 +pstree -p
 +</​code>​
 +>​l'​option -p permet d'​afficher le PID en plus de la hiérarchie.
 +
 +Pour se faire très plaisir ^_^ en observant la liste des processus de manière dynamique :
 +<code user>
 +top
 +</​code>​
 +Pour aller plus loin sur la récupération du PID voir : 
 +  * [[doc:​systeme:​ps?​s[]=ps|la commande ps]]
 +  * [[doc:​systeme:​top?​s[]=top|la commande top]]
 +  * [[http://​fr.wikibooks.org/​wiki/​Le_syst%C3%A8me_d%27exploitation_GNU-Linux/​Processus]]
 +
 +=== Exemple pratique : tuer un processus ===
 +Imaginons que vous vous êtes endormi devant votre messagerie.\\ A votre réveille 8-o : impossible de fermer la fenêtre de icedove avec la souris.\\
 +Dans ce cas, le plus simple est tuer le processus d'​exécution de icedove.
 +  * Retrouver le processus :
 +  - ouvrir par exemple TTY1 : ctrl+Alt+F1
 +  - se loguer et entrer son mot de passe utilisateur
 +  - récupérer le PID du processus icedove : 
 +<code user>
 +ps -A | grep icedove
 +</​code>​
 +  * Tuer le processus :
 +<code user>
 +4245  pts/0   ​00:​00:​02 ​ icedove
 +</​code>​
 +<code user>
 +exit
 +</​code>​
 +  * Revenir sur l'​interface graphique : ctrl+Alt+F7
 +
 +Quelques exemples pour illustrée la notion de processus : 
 +  * [[atelier:​chantier:​script-bash-variables-arguments-parametres?&#​exportation-de-la-valeur-d-une-variable|Exportation de la valeur d'une variable]].
 +  * [[atelier:​chantier:​script-bash-enchainement-de-commandes-et-etat-de-sortie#​notion-de-sous-shell|sous-shell]]
  
 ===== Quotes, apostrophe, guillemets et apostrophe inversée ===== ===== Quotes, apostrophe, guillemets et apostrophe inversée =====
Ligne 228: Ligne 307:
 <code user>​ls</​code>​ <code user>​ls</​code>​
 <​code>​dossier1 ​ dossier2 ​ dossier3</​code>​ <​code>​dossier1 ​ dossier2 ​ dossier3</​code>​
-  * puis (**Attention,​ cette commande est dangereuse, elle efface tout le contenu du dossier, à ne pas taper dans votre dossier personnel sous peine de tout perdre de manière irrémédiable !**) : 
 <code user>rm `ls`</​code>​ <code user>rm `ls`</​code>​
-  * et pour vérifier que tout a été supprimé :​+<note warning>​ 
 +Attention, cette commande est dangereuse !\\  
 +Elle efface tout le contenu du dossier.\\  
 +À ne pas lancer dans votre dossier personnel sous peine perdre de manière irrémédiable de tous vos fichiers ​ ! 
 +</​note>​ 
 +>​Pour ​vérifier que tout a été supprimé :​
 <code user>​ls</​code>​ <code user>​ls</​code>​
  
Ligne 240: Ligne 323:
 <​code>​dossier1 ​ dossier2 ​ dossier3</​code>​ <​code>​dossier1 ​ dossier2 ​ dossier3</​code>​
  
-  * puis: 
 <code user>ls | xargs rm <code user>ls | xargs rm
 </​code>​ </​code>​
-  * et pour vérifier que tout a été supprimé :​+>​Pour ​vérifier que tout a été supprimé :​
 <code user>​ls</​code>​ <code user>​ls</​code>​
  
Ligne 251: Ligne 333:
 </​code>​ </​code>​
  
-Cette commande affiche le contenu du répertoire courant à l'​écran. Elle est (presque) ​strictement ​équivalente à ls.+>Cette commande affiche le contenu du répertoire courant à l'​écran. 
 +>Elle est (presque) ​ équivalente à ls.
  
   * **À voir** : [[http://​abs.traduc.org/​abs-5.0-fr/​ch11.html|Guide avancé d'​écriture des scripts Bash: 11. Substitution de commandes]]   * **À voir** : [[http://​abs.traduc.org/​abs-5.0-fr/​ch11.html|Guide avancé d'​écriture des scripts Bash: 11. Substitution de commandes]]
doc/programmation/shells/bash-les-differents-caracteres-speciaux.txt · Dernière modification: 01/04/2023 19:17 par agp91

Pied de page des forums

Propulsé par FluxBB