UNIX - Part2
UNIX - Part2
UNIX - Part2
DES GROUPES
§ Les comptes d’utilisateurs
§ Root:
§ Super utilisateur
§ Les permissions d’accès ne sont pas testées
§ Administrateur du système
§ ftp, bin, news…
§ Comptes utilisateurs utilisés par les applications
§ Ne peuvent pas (ne doivent pas) être utilisés comme login
§ Comptes ordinaires
§ Comment être un root?
§ Le nom de l’administrateur du système linux est « root »
§ Pour avoir les privilèges de l’administrateur il faut se connecter en tant que « root »
§ Via le terminal administrateur en mentionnant le mot de passe de l’utilisateur « root »
§ En étant connecté déjà via un utilisateur simple et en utilisant la commande « su »
§ Le compte « root » est désactivé dans certaines distributions, le passage aux privilèges d
super utilisateur se fait à travers la commande « sudo »
§ Les comptes d’utilisateurs
§ Chaque utilisateur est reconnu par son login et son mot de passe
§ Un utilisateur peut appartenir à un ou plusieurs groupes
§ Les utilisateurs et les groupes sont repérés dans le système par des numéros : uid pour le
numéro d'utilisateur (User IDentifier) et gid pour le numéro de groupe (Group IDentifier).
§ L’identification des utilisateurs se fait par le fichier /etc/passwd
§ L’identification des groupes se fait par le fichier /etc/group
§ Les mots de passes cryptés sont accessibles uniquement à l’administrateur via le fichier
/etc/shadow
§ Chaque utilisateur est une ligne dans le fichier /etc/passwd
§ le fichier /etc/passwd contient la liste des utilisateurs système. Ce fichier est
accessible en lecture à tous les utilisateurs et est de la forme suivante:
login:passwd:uid:gid:comment:home:shell
§ Il contient:
§ Login: Nom de connexion (login) de l’utilisateur,
§ Passwd: Un caractère x: correspond au mot de passe de l'utilisateur
§ Uid: Le numéro de l’utilisateur (UID = user identifier),
§ Gid: Le numéro de groupe (GID = group identifier),
§ Comment: Commentaire textuel sur l'utilisateur qui peut contenir son nom réel, numéro de
téléphone, etc.
§ Home: Le répertoire personnel de l’utilisateur,
§ L'interpréteur Shell par défaut de l'utilisateur (csh, sh, bash, etc.).
§ Les commandes de gestion des utilisateurs
§ Changer l’identité de l’utilisateur connecté : su
§ Syntaxe: su [options] [nom_utilisateur]
§ nom_utilisateur est l’utilisateur dont on veut prendre l’identité
§ Si aucun utilisateur n’est spécifié le changement se fait vers l’utilisateur root
§ La commande demande un mot de passe avant de s’exécuter sauf pour le root
§ Exemple: su - test
§ Les commandes de gestion des utilisateurs
§ Créer un nouvel utilisateur: useradd
§ Syntaxe: useradd [-c ’’commentaire’’] [-d répertoire] [-e date_expiration]
[-g groupe_primaire] [-G groupes_secondaires]
[-p mot_de_passe] [-s shell] [-u uid] login
§ Exemple:
useradd -c ’’tri101’’ -d /home/stage -g reseau -G admin -p P@ssw0rd –s /bin/bash –u 501 etudiant
§ Modifier un utilisateur existant: usermod
§ Syntaxe: usermod [-c ’’commentaire’’] [-d répertoire] [-e date_expiration]
[-g groupe_primaire] [-G groupes_secondaires] [-p mot_de_passe] [-s shell] [-u uid]
[-l nouveau_login] login
§ Exemple:
usermod –l student etudiant
usermod –c ’’employé en essai’’ –d /home/employe –e 20141230 student
§ Les commandes de gestion des utilisateurs
§ Supprimer un utilisateur: userdel
§ Syntaxe: userdel [-r] login
§ -r: pour supprimer un utilisateur et aussi son répertoire personnel.
§ La commande userdel supprime toute trace de l'utilisateur dans le fichier de configuration :
/etc/passwd y compris dans les groupes d'utilisateurs.
§ Exemple: userdel mohamed (supprime l’utilisateur mohamed et non pas son répertoire personnel).
userdel –r ali (supprime l’utilisateur ali ainsi que son répertoire personnel).
§ Commande « who »
§ Affiche les utilisateurs connectés
§ Le fichier /etc/passwd est public (toute personne qui a un compte sur la machine
peut le lire).
§ Pour contrecarrer cette faille, certains systèmes ont introduit le fichier /etc/shadow
§ lisible uniquement par root
§ contient les mots de passe des utilisateurs, qui disparaissent alors de
/etc/passwd.
§ Si on ajoute un utilisateur à la main, cela implique d'éditer les 2 fichiers.
§ Une ligne /etc/shadow est composée des champs suivants:
§ Login.
§ Mot de passe crypté. Une * dans ce champ indique le compte ne peut être connecté (cas du compte bin
par exemple). Un mot de passe commençant par !! indique que le compte est verrouillé (désactivé).
§ Date de dernière modification du mot de passe (en nombre de jour depuis le 1er janvier 1970 ).
§ Période de changement : Le nombre minimum de jours entre deux changements de mots de passe. Un 0
indique que l'utilisateur peut changer le mot de passe à n'importe quel moment.
§ Durée de validité : Le nombre maximum de jours pendant lesquels le mots de passe est valide (depuis
1/1/1970). La valeur 99999 indique que le mot de passe est toujours valide.
§ Durée d’alerte : nombre de jours pour lequel un utilisateur est averti que son mot de passe expirera.
§ Le nombre de jours après quoi le mot de passe expire de sorte que le compte est désactivé. -1 est utilisé
pour indiquer un nombre infini de jours
§ Date d'expiration : Exprimée en nombre de jour depuis la date de référence (1/1/70)
§ Exemple:
jack:Q,Jpl.or6u2e7:10795:0:99999:7:-1:-1:134537220
§ Chaque utilisateur doit faire partie de au moins un groupe
§ Dans /etc/passwd chaque utilisateur possède un groupe par défaut
§ Le fichier /etc/group rassemble la liste des groupes.
§ Un groupe d’utilisateurs rassemble un certain nombre d’utilisateurs pouvant facilement
partager des fichiers.
§ Le fichier /etc/group est de la forme suivante:
nom_du_groupe:mot_de_passe:GID:liste_utilisateurs
§ Il contient:
§ Nom du groupe,
§ Un mot de passe du groupe (vide ou X)
§ Un numéro du groupe (GID = group identifier),
§ [ liste des utilisateurs membres du groupe ].
§ Les commandes de gestion des groupes
§ Pour lister tous les groupes d'un utilisateur :
§ groups nom_utilisateur
§ Pour créer un nouveau groupe
§ Syntaxe groupadd [-g gid] nom_groupe
§ Exemple: groupadd –g 1220 ensias
groupadd ensias
§ Supprimer un groupe :
§ Syntaxe groupdel nom_groupe
§ Le groupe est supprimé du fichier /etc/group.
§ modifier un groupe
§ groupmod [-g gid] [-n nouveau_nom_groupe] nom_groupe
§ Ajouter ou supprimer un utilisateur d’un groupe: gpasswd
§ gpasswd -a etudiantensias (Ajoute l’utilisateur stagiaire au groupe reseau).
§ gpasswd -d etudiant ensias (Supprime l’utilisateur stagiaire du groupe reseau).
§ Les commandes de gestion des groupes
§ Il y'a trois possibilités pour appartenir à un groupe :
§ Le groupe est votre groupe initial (principal) défini dans /etc/passwd.
§ Le groupe est un de vos groupes supplémentaires définis dans /etc/group.
§ Vous connaissez le mot de passe associé au groupe et vous vous connectez à ce groupe grâce à la
commande newgrp.
GESTION DES DROITS
§ Le système Linux est un système multi-utilisateurs où l’accès aux fichiers est contrôlé par des droits.
§ La commande ls –l permet de les afficher.
§ Pour contrôler l’accès à un fichier, le système UNIX divise les utilisateurs en quatre catégories:
§ u : le propriétaire (user)
§ g : le groupe (group)
§ o : les autres (others)
§ a : user, group et other (all)
§ ainsi que quatre types de droits
§ r : lecture (read)
§ w : écriture (write)
§ x : exécution
§ - : aucun droit
§ Pour un répertoire
§ Lecture: Afficher le contenu du répertoire (ls)
§ Ecriture: créer supprimer un fichier dans le répertoire (vi, nano, rm, etc.)
§ Exécution: traverser (cd)
§ Pour un fichier
§ Lecture: Afficher le contenu (more, less, cat, etc.)
§ Ecriture: modifier le contenu
§ Exécution: exécuter le contenu
§ si vous essayez de copier un fichier dans un sous-
répertoire (cp fich1 rep2/rep3),
§ il faut disposer des droits suivants:
1. lire le fichier fich1 : droit en lecture sur le fichier
2. traverser les sous-répertoires rep2 et rep3 : droit x au moins pour vous,
3. écrire dans rep3 : droit W
§ La modification des droits:
§ Commande chown
§ Permet de modifier le propriétaire et le group associés au fichier
§ Syntaxe : chown nouveau_propriétaire fichier
chown nouveau_propriétaire.nouveau_group fichier
chown nouveau_propriétaire. fichier //dans le cas ou le propriétaire et le groupe ont le
même nom
§ Pour changer le propriétaire d’un répertoire et de ses sous-répertoires, on utilise
l’option –R
§ Exemple: chown -R new_user:groupe chemin_du_répertoire (ici chemin_du répértoire est facultatif)
§ Commande chgrp
§ Syntaxe : chgrp nouveau_group fichier
§ L’option –R permet d’utiliser la récursivité sur les répertoires
§ Exemple: chgrp -R new_groupe chemin_du_répertoire
§ La modification des droits : chmod
§ Pour un fichier les droits sont exprimés par une chaîne de 10 caractères :
§ tuuugggooo
§ t : type du fichier
§ uuu : droits du propriétaire
§ ggg : droits du groupe
§ ooo : droits des autres
:
§ Exemple -rwxr-x---
dr-xrwxr--
§ Pour modifier le droit d'accès d'un fichier donné, utiliser la commande chmod (voir man chmod).
§ chmod u+r toto donne le droit de lire le fichier toto à l'utilisateur (vous même)
§ chmod g+w toto autorise une personne du même groupe que vous à lire le fichier
§ chmod o-x toto les autres ne sont pas autorisés à exécuter le fichier
§ chmod a+rx toto autorise le propriétaire, le groupe et les autres à lire et exécuter le fichier.
§ chmod u=rwx,g=rx,o=- toto fixe r,w et x pour propriétaire puis r et x pour le groupe et ne donne aucun droit
aux autres.
§ Représentation des droits en octal