Prise de contact avec Unix : Différence entre versions

De Wicri Manuel
imported>Jacques Ducloy
(Prise de contact avec le shell d'Unix)
imported>Jacques Ducloy
(Objectifs de ce module)
Ligne 9 : Ligne 9 :
 
sh KazakhstanV1/bin/AreaCreateData.sh
 
sh KazakhstanV1/bin/AreaCreateData.sh
 
</pre>
 
</pre>
 +
 +
Ce wiki donne accès à un exemple de Serveur d'exploration sur Rabelais, avec des pages contenant d'autres exemples de shell.
 +
Voir notamment :
 +
* [[Serveur d'exploration sur Rabelais]]
  
 
Le but de cette page est d'aider le lecteur à comprendre ce type de directives pour qu'il soit capable de les adapter à ses propres besoins.
 
Le but de cette page est d'aider le lecteur à comprendre ce type de directives pour qu'il soit capable de les adapter à ses propres besoins.

Version du 4 septembre 2013 à 15:27

Ce module a pour objet de familiariser l'utilisateur avec l'utilisation élémentaire d'Unix (appel de commandes et manipulations simples de fichiers). En effet la génération de Serveurs d'exploration s'effectue avec le langage de commande d'Unix.

Objectifs de ce module

La création d'un serveur d'exploration et de sa plateforme associée s'effectue à l'aide de commandes Unix. On trouvera donc sur le réseau de nombreux exemples de suites de commande Unix pour réaliser une opération.

Par exemple, la génération d'un serveur sur la recherche au Kazakhstan (accessible sur Wicri/Europe) se fait à l'aide de tables. Une page est par exemple dédiée à la génération des données (wicri-europe.fr:Wicri:KazakhstanV1/Paramètres, data). Cette page contient des scripts tels que :

sh KazakhstanV1/bin/AreaReset.sh
ExplorAreaInit -l wicri-europe.fr -p "Wicri:KazakhstanV1/Paramètres" -d KazakhstanV1
sh KazakhstanV1/bin/AreaCreateData.sh

Ce wiki donne accès à un exemple de Serveur d'exploration sur Rabelais, avec des pages contenant d'autres exemples de shell. Voir notamment :

Le but de cette page est d'aider le lecteur à comprendre ce type de directives pour qu'il soit capable de les adapter à ses propres besoins.

Prise de contact avec le shell d'Unix

Le système Unix est piloté par un langage de commande nommé « shell ». Plus exactement, plusieurs langages de commandes sont généralement disponibles sur une installation, par exemple :

  • le shell standard ou « Bourne shell » (sh)
  • le C shell (csh), dont la syntaxe est plus proche du C

Dans ce chapitre, nous resterons à un niveau de généralité compatible avec ces différentes versions.

Une session shell est une suite d'appels de commandes, avec ou sans paramètres. Par exemple, la commande :

date

donne l'heure à l'opérateur.

Pour en savoir plus sur cette commande, on peut appeler la commande man avec comme paramètre date pour en obtenir le mode d'emploi, exemple :

man date

Une autre commande utile est la commande echo qui écrit simplement la zone paramètre sur la sortie standard (écran). Ainsi la commande :

 echo coucou

va écrire coucou, suivi d'un saut de ligne, sur la ligne courante.

Dans l'exemple donné au paragraphe « objectifs », la ligne « sh KazakhstanV1/bin/AreaReset.sh » provoque un effacement de la plateforme avant une nouvelle génération. La commande sh (shell) va lancer le shell contenu dans le fichier KazakhstanV1/bin/AreaReset.sh.

Les paragraphes qui suivant détaillent les mécanises de désignation de fichiers.

La hiérarchie des fichiers Unix

Chemins absolus

L'espace disque d'Unix est organisé en une hiérarchie de répertoires (directories) qui contiennent d'autres répertoires ou des fichiers. Tous ces éléments partent d'une racine unique (root).

Pour désigner un fichier ou un répertoire, on utilisera un chemin (path). Un chemin sera dit absolu s'il part de la racine, un tel chemin commencera toujours par un caractère « barre de fraction (slash) ».

La commande «ls» permet d'obtenir la liste des éléments repérés par un chemin. Par exemple pour obtenir les répertoires les plus proches de la racine, il suffit de faire :

ls /

On obtient ainsi une liste de répertoires avec notamment « bin » qui contient des programmes publics et « user » qui constitue la base de la gestion des usagers. Pour explorer la liste des usagers, on peut continuer à utiliser la commande ls avec un premier niveau de répertoire, par exemple :

ls /users

Répertoires de travail, chemins relatifs

En cours de session, l'utilisateur travaille à partir d'un répertoire privilégié nommé « working directory » ou répertoire courant. Au démarrage d'une session celui-ci est un répertoire propre à l'usager (home directory).

En utilisant la commande :

pwd

En début de session, on obtient l'adresse absolue du « home directory ».

Il est possible de créer de nouveaux répertoires par la commande mkdir (make directory). Dans la suite de ce paragraphe nous allons construire une hiérarchie de répertoires tout à fait classique des serveurs d'exploration :

  home directory
----------------+                 Import
                | Corpus         +--------
                +--------+       |
                |        | Japon |
                         +-------+ Archive
                         |       +---------+