720 likes | 905 Views
UNIX: Système de Gestion de Fichiers. INTRODUCTION. Système de Gestion de Fichiers Sous système Unix Les fichiers : fichiers du système d’exploitation programmes bibliothèque paramètres périphériques gérés à travers des fichiers moyens de communications entre processus
E N D
INTRODUCTION • Système de Gestion de Fichiers • Sous système Unix • Les fichiers : • fichiers du système d’exploitation • programmes • bibliothèque • paramètres • périphériques gérés à travers des fichiers • moyens de communications entre processus • fichiers de données
Interface appels système Système de gestion des processus Système de gestion des fichiers cache système d’E/S caractères blocs contrôleurs Interface matériels
Les périphériques • Système de gestion des E/S • couche entre le S.G.F et le matériel • Primitives d’accès aux périphériques dans les pilotes • pilotes périphériques type caractères • pilotes périphériques type blocs • Actions sur lescontrôleurs • un contrôleur par type de périphérique • Caractéristique Unix: • Interface d’appel périphérique utilise le SGF • un périphérique = un fichier type caractère ou bloc
Les moyens de communications Unix • tube anonyme • fichier sans nom • type FIFO • communication entre processus de même filiation • tube nommé • fichier avec nom • type FIFO • communication entre processus quelconques • socket • fichier de communication entre processus distants
GÉNÉRALITÉS • Le système de fichiers • gestion de un ou plusieurs systèmes de fichiers • montage possible: système unique • un système de fichiers accessible sur disque par: • un n° périphérique logique n° du système = n° de périphérique • des adresses physiques calculées par le pilote
Fichier: • ensemble de données: fichier logiciel • répertoire (d) • ordinaire : programmes, données.... (-) • tubes nommés (p) • sockets (s) • liens (l) • ressource périphérique: fichier matériel • bloc (b) • caractères (c) • identifié par un nom • généralement sur disque
Organisation/disque • bloc • unité d’échange: 512, 1024... octets • blocs du système • boot: 1er bloc ou autres blocs sur disque • super-bloc: état du système de fichiers • n° premiers blocs libres • liste des i-noeuds libres • table des i-noeuds configurée à l’installation • blocs des données bloc 0 super-bloc table des i-noeuds données
Le super bloc - Gestion de l’espace disque • la taille du S.F. • le nombre de blocs libres dans le S.F • une liste des blocs libres disponibles dans S.F • l’indice du 1er bloc libre dans la liste des blocs libres • la taille de la table des i-noeuds • le nombre d’i-noeuds libres dans le S.F • une liste d’i-noeuds libres dans le S.F. • l’indice du 1er i-noeud libre dans la liste des i-noeuds libres • des champs verrous pour les listes des blocs et i-noeuds libres • un drapeau indiquant si le super bloc a été modifié
Arborescence racine dir_3 toto.c • situer un fichier dans l’arborescence • son nom • son chemin d’accès: /dir_3/ toto.c • fichiers système: idem mais avec protections renforcées
dir_3 17 prog.c 26 toto.c 21 dir_b nom du fichier n° i-noeud • Notion de fichier • identification: nom du fichier • localisation fichier par l’algorithme ‘namei’ • parcourt des blocs de données type‘répertoire’ • recherche du nom du fichier • i-noeud du fichier dans la table des i-noeuds • pointeurs vers blocs de données
répertoire • fichier référencé dans la table des i-noeuds • pointe vers des blocs de données type‘répertoire’ • bloc données répertoire = n * 16 octets • n° i-noeud • nom du fichier ou répertoire • racine /: i-noeud n° 2 bloc de données type ‘répertoire’ 17 prog.c 26 fic.txt 21 dir_a nom du répertoire 2 octets 14 octets n° i-noeud
Algorithmes • L’algorithme ‘namei’ appelle d’autres algorithmes: • ‘iget’ attribuer i-noeud en mémoire • ‘iput’ libérer i-noeud en mémoire • ‘bmap’ maj paramètres noyau pour accès fichier • D’autres algoritmes: • ‘alloc’ réservation espace fichier sur disque • ‘free’ libération espace fichier • ‘ialloc’ réservation i-noeud pour un fichier • ‘ifree’ libération i-noeud d’un fichier
LES I-NOEUDS • définition • i-noeud (i-node) est un descripteur conservant les informations du fichier sur disque • i-noeud = noeud d’index • 64 caractères/ i-noeud • table des i-noeuds configurée à l’installation n°1 blocs défectueux n°2 racine pour le système de fichiers • gestion des i-noeuds • sur disque • en mémoire
i-noeud sur disque • un fichier = un i-noeud + bloc de données • table des i-noeuds après le super-bloc • un n° = n° entrée dans table des i-noeuds du disque • i-noeud utilisé par le noyau • contenu des informations dans un i-noeud (64 octets): • nom propriétaire • type du fichier • permissions • date dernier accès • nombre de liens vers d’autres fichiers (répertoire) • table des adresses des données • taille: nombre d’octets
Exemple un i-noeud dupont etudiants ordinaire rwxr--r-x 23 nov 1999 14:25 22 nov 1999 12:54 23 nov 1999 14:15 5412 octets table d’adresses des blocs de données propriétaire groupe type du fichier droits d’accès date dernier accès date fichier modifié date i-noeud modifié taille adresses données
i-noeud en mémoire • appel fichier => copie i-noeud en mémoire • ajout d’informations pour accès physique aux données • état i-noeud: bloqué ou non • n° logique périphérique • n° ligne dans table des i-noeuds en mémoire • pointeurs: chaînage des i-noeuds en mémoire • compteurs de fichiers ouverts
Contrôle des accès • verrou: protection des utilisations multiples • flag : processus en attente d’accès • compteur d’accès : si zéro demande , i-noeud recopié sur disque • Liste des i-noeuds libres en mémoire • si compteur i-noeud =0 alors placé dans cette liste • i-noeuds inactifs = un cache • réallocation si demande à nouveau • technique limitant les accès disque • libération des i-noeuds plus anciens si cache plein
Attribuer un i-noeud mémoire • demande d’accès à un fichier: • procédure ‘namei’ nom fichier -> n° i-noeud -> table des i-noeuds disque • procédure d’attribution i-noeud mémoire • iget () • deux cas: • i-noeud n’est pas en mémoire • i-noeud est en mémoire • dans les i-noeuds (actif) • dans la liste des i-noeuds libres (inactif)
i-noeud n’est pas en mémoire • recherche adresse physique de l’entrée de l’i-noeud dans table des i-noeuds disque N° bloc: ((n°i-noeud-1) / nb i-noeuds par bloc) + n° 1er bloc table des i-noeuds (( 8 - 1 ) / 3 ) + 10 = 7 / 3 + 10 = 2 + 10 = 12 N° octet: ((n°i-noeud-1) modulo (nb i-noeuds par bloc)) * taille d’un i-noeud (( 8 - 1 ) modulo 3 ) * 64 = 7 modulo 3 * 64 = 1 * 64 = 64 • copie i-noeud dans les i-noeuds en mémoire en récupérant une place dans la liste des i-noeuds libres
i-noeud est en mémoire • actif • verrouillé alors attente • non verrouillé compteur accès +1 • inactif dans le cache • réallocation i-noeud mémoire • compteur accès +1
Libération d’un i-noeud mémoire • libération i-noeud: accès libéré • procédure libération i-noeud de la mémoire • iput () • compteur = compteur -1 • si compteur = 0 plus aucun processus • copie i-noeud maj sur disque • i-noeud mémoire placé dans la liste des i-noeuds libres en mémoire • remarque: si compteur de liens nul (plus aucune données dans le fichier) alors suppression des blocs de données
Création d’un i-noeud disque • création d’un fichier • paramètres: • nom du fichier • chemin d’accès jusqu’au répertoire • procédure d’allocation d’un i-noeud sur disque • ialloc() recherche i-noeud libre • scrute liste des i-noeuds libres dans super-bloc • la liste est vide • la liste n’est pas vide
Cas liste vide : • recherche de tous les i-noeuds libres de la table des i-noeuds (type = 0) • maj de la liste des i-noeuds libres dans super bloc • si aucun i-noeud libre alors ... plus de place • Cas liste non vide: • choix i-noeud ‘plus grand n° libre’ • accès à l’i-noeud disponible dans la table des i-noeuds • Dans les deux cas: • écrire les éléments dans l’i-noeud de la table des i-noeuds • décompter le nombre d’i-noeuds libres dans super bloc • libérer l’i-noeud dans la liste des i-noeuds libres du super bloc
liste des i-noeuds libres (super-bloc) 12 17 54 125 127 250 vide table des i-noeuds d blocs de données entrée n°250 0 - l d
Suppression d’un i-noeud disque • suppression d’un fichier • paramètres: • nom du fichier • chemin d’accès jusqu’au répertoire • procédure de suppression d’un i-noeud sur disque • ifree() suppression dans table des i-noeuds disque • verrou super bloc doit être libéré • scrute liste des i-noeuds libres dans super-bloc • encore de la place dans la liste • la liste est pleine
Cas place dans la liste: • ajout n° i-noeud libéré • maj ‘plus grand n° libre’ dans super bloc • maj compteur nombre i-noeuds libres • Cas liste pleine: • si n° i-noeud libéré < ‘plus grand n° libre’ • n° i-noeud libéré remplace ‘plus grand n° libre’ • sinon pas de maj liste • Dans les deux cas: • maj table des i-noeuds disque (type = 0) • suppression des blocs de données
L’INTERFACE D’ACCÈS • Primitives d’accès à un fichier • par une commande du shell ou script • par une requête lors d’un appel dans un programme • Deux types de données • données mémoire: • procédures système d’accès • informations temporaires • données disque: • données attachées au fichier sur disque
Descripteur • infos fichier sont tranférées en mémoire • un descripteur par fichier et par processus • interface entre le processus et le S.F. pour les échanges • Descripteurs particuliers • entrée standard (clavier): n° 0 • sortie standard (écran): n°1 • sortie erreur (fichier erreurs): n°2 • Structure d’un descripteur: • /usr/sys/include/sys/user.h
Table des fichiers • une table des fichiers pour tous les processus gérée par le noyau • créée à partir de la table des i-noeuds disque • description des propriétés du fichier et éléments pour l’accès • un appel fichier = une entrée dans la table • avec opération demandée (r,w,r/w) • structure d’une entrée dans /usr/sys/include/sys/file.h • chaque élément de la table pointe l’i-noeud du fichier dans liste des i-noeuds en mémoire
descripteurs table des fichiers Liste des i-noeuds proc_1 Fic_A Fic_A R Fic_A proc_2 Fic_A R/W Fic_A
LES PERMISSIONS • Contrôle des accès aux fichiers renforcé sous Unix: • système multi utilisateurs • fichiers système et fichiers utilisateurs sous le même système de gestion des fichiers • niveaux de protection: • droits -> r: lecture w: écriture x: exécution • pour le propriétaire du fichier • pour le groupe d’usagers dans lequel se situe le propriétaire • pour tous les autres utilisateurs • décision des niveaux de protection: • le propriétaire • le su
ORGANISATION DES FICHIERS SUR DISQUE • Organisation • non contigüe, aléatoire • Gestion dynamique de l’espace du disque • Blocs • de taille égale • 3 types • blocs de données • blocs directs: adresses des blocs de données • blocs indirects: adresses des blocs directs ou indirects • table des i-noeuds sur disque utilise ces différents types de blocs
Pour chaque i-noeud de la table des i-noeuds: • 13 blocs: une table des adresses des blocs fichiers • 10 blocs directs: 10 n° de blocs de données • 3 blocs indirects: • n° bloc indirect simple: n° du bloc ayant 256 n° de blocs directs • n° bloc indirect double: n° du bloc ayant 256 n° de blocs indirects • n° bloc indirect triple: n° du bloc ayant 256 n° de blocs indirects double • si: • adresse sur 32 bits et bloc de 1024 octets => taille maxi / fichier 16 GO • un bloc libre est à zéro
Attribution des blocs • super bloc • nb de blocs libres • une liste • de 50 n° de blocs libres (cache) • un pointeur vers d’autres listes de blocs libres • utilitaire mkfs: création S.F. • chaînage des blocs libres • algorithme alloc() • allocation d’un bloc à un fichier à partir de la liste • si liste pleine: n° bloc pris dans la liste • si liste épuisée: liste suivante remplace liste super bloc
Exemple: liste des blocs libres dans super bloc super bloc 14 21 105 52 25 10 pointeur 82 72 27 103 18 46 68 261 bloc 14
Récupération d’un bloc libre: liste des blocs libres dans super bloc pleine super bloc 14 21 105 52 25 10 107 bloc 107 attribué alors: super bloc 14 21 105 52 25 10
Récupération d’un bloc libre liste des blocs libres dans super bloc vide super bloc 11 14 21 105 52 25 10 107 77 bloc n°11 bloc 11 attibué alors: liste des blocs libres dans super bloc super bloc 14 21 105 52 25 10 107 77
Libération des blocs • super bloc • recherche d’un bloc libre • algorithme free() • libération des blocs d’un fichier • attachement à la liste des blocs libres du super bloc • si liste non pleine: maj dans cette liste • si liste pleine: liste pleine écrite dans ce bloc libéré et un pointeur dans la liste sur ce nouveau bloc libre
liste des blocs libres dans super bloc pleine super bloc 14 21 105 52 25 10 107 77 bloc 11 libre alors: super bloc 11 14 21 105 52 25 10 107 77 bloc n°11
liste des blocs libres dans super bloc non pleine super bloc 14 21 105 52 25 10 107 bloc 11 libre alors: super bloc 14 21 105 52 25 10 107 11
Répertoires • Fichier de type ‘d’ • Accéder à un i-noeud d’un répertoire permet d’accéder aux blocs de données du répertoire • Blocs de données du répertoire comme les fichiers: • blocs données • blocs directs • blocs indirects • Données au format: • n° i-noeud du fichier • nom de fichier
Chemin d’accès • Définir le chemin d’accès au fichier • syntaxe: • chaîne de caractères • plusieurs éléments séparés par / • chaque élément est un nom de répertoire • dernier élément est le nom du fichier • le pemier / est le répertoire racine /users/étudiants/informatique/gaston/fichier.exe
répertoire particuliers . répertoire courant .. répertoire parent • un n° i-noeud associé à chacun des noms de fichier dont: • le répertoire courant • le répertoire parent
. . Bloc répertoire bloc 125 répertoire .. .. 1 9 1 1 4 bin i-noeud 9 17 claude i-noeud 44 7 - 57 luc infos 5 lib infos 44 prog.exe 3 etc 125 688 9 usr nom fichier /usr /usr/prog.exe n° i-noeud
Conversion nom_fichier en i-noeud • n° i-noeud et nom fichier dans bloc données du répertoire • l’algorithme ‘namei’ • pour chaque niveau convertit nom et n° • vérifie les droits d’accès • parcourt les niveaux jusqu’à trouver le nom du fichier
LES PRIMITIVES • Structure commune des fichiers • dans /usr/sys/include/sys/stat.h struct stat { dev_t st_dev; identif disque logique ino_t st_ino; n° fichier sur disque mode_t st_mode; type du fichier et droits accès nlink_t st_nlink; nb liens physiques uid_t st_uid; propriétaire gid_t st_gid; groupe dev_t st_rde; identif disque logique (bloc/car) off_t st_size; taille en octets time_t st_atime; date dernier accès
int st_spare1; time_t st_mtime; date dernière modif int st_spare2; time_t st_ctime; date dern modif i-noeud int st_spare3; uint_t st_blksize; taille d’un bloc dans un fichier int st_blocks; blocs alloués pour le fichier uint_t st_flags; flags utilisateur uint_t st_gen; n° génération du fichier };
Informations fichier • récupération dans une structure stat des informations du fichier #include <sys/types.h> #include <sys/stat.h> int stat (const char *ef, struct stat *pt_stat) int fstat (const int desc, struct stat *pt_stat) ex: struct stat bufstat if (stat(“fic1.c”, &bufstat) ==-1) perror (“erreur stat”);