fstab : Explications sur le fichier et sa structure
Table des matières
Le fichier fstab (situé dans /etc/fstab) est le fichier de configuration qui contient les informations statiques sur le montage des systèmes de fichiers que vous utilisez régulièrement.
Il liste, tous les disques et partitions disponibles, et indique comment ils peuvent être initialisés, et intégrés dans le système de fichiers du système global.
Le fichier fstab ressemble à ceci sur mon serveur :
Le fichier est composé d'une ligne par système de fichier et de 6 champs, séparés par un espace ou une tabulation :
Je vais reprendre la ligne de mon exemple pour décrire à quoi sert chaque option :
La première colonne indique le nom du périphérique ou les autres moyens de localiser la partition ou la source de données.
Ici, elle est repérée grâce à son UUID (chose commune de nos jours)
Mais il est possible de renseigner la partition concernée de plusieurs façons :
La deuxième colonne indique le point de montage dans l’arborescence du système de fichiers global.
Dans mon exemple, /.
Les valeurs peuvent prendre n'importe quel dossier le l'arborescence
La troisième colonne indique le type de système de fichiers ou l’algorithme utilisé pour l’interpréter.
Dans mon exemple, c'est ext4.
Parmi ces valeurs, on peut rencontrer : ext2, ext3, ext4, reiserfs, xfs, jfs, smbfs, btrfs, vfat, ntfs, swap
La quatrième colonne définit des options particulières pour les systèmes de fichier. Certaines options sont pour le système de fichiers lui même. Les options indiquées dans le fichier fstab sont les mêmes que celles de la commande mount. Les options les plus répandues sont :
Il est possible de spécifier plusieurs options et de les séparer par une virgule.
Dans mon exemple, si je veux en plus de noatime spécifier acl :
Cette colonne a toujours été mystérieuse pour moi. D'après quelques documentations sur Internet j'en suis arrivé à l'utilisation suivante :
Cette valeur est utilisée par l'utilitaire dump pour décider quand faire des sauvegardes. Quand il est installé, dump vérifie le chiffre inscrit et décide si le système de fichiers doit être sauvegardé. Les valeurs possibles sont 0 et 1. Si 0, dump va ignorer le système de fichier, si 1, dump fera une sauvegarde. La plupart des utilisateurs n'auront pas dump d'installé, ils pourront donc inscrire 0 dans le champ <dump>.
Cette colonne indique la priorité de vérification du système de fichiers par l'utilitaire fsck.
fsck lit le chiffre et détermine dans quel ordre les systèmes de fichiers vont être vérifiés. Le champ peut prendre les valeurs 0,1 et 2. Le système de fichiers root devra avoir la priorité la plus haute : 1, tout les autres systèmes que vous voulez vérifier devront avoir un 2. Les systèmes de fichiers avec un 0 ne seront pas vérifiés par l'utilitaire fsck.
Introduction
Le fichier fstab (situé dans /etc/fstab) est le fichier de configuration qui contient les informations statiques sur le montage des systèmes de fichiers que vous utilisez régulièrement.
Il liste, tous les disques et partitions disponibles, et indique comment ils peuvent être initialisés, et intégrés dans le système de fichiers du système global.
A quoi ressemble le fichier
Le fichier fstab ressemble à ceci sur mon serveur :
Code BASH :
# / was on /dev/sda1 during installation UUID=fd0587f2-d0d0-404c-b4c3-aa358b8dacd6/ext4noatime0 1 # /home was on /dev/sda4 during installation UUID=377d38df-2140-4440-80fd-904271438ad1/homeext4noatime0 0 # /var was on /dev/sda3 during installation UUID=46a177d7-9856-4137-95a1-432e61085bde/varext4noatime0 0 # swap was on /dev/sda2 during installation UUID=1bd06a09-070e-447d-a3bf-553670128bf8noneswapsw0 0
Explications
Le fichier est composé d'une ligne par système de fichier et de 6 champs, séparés par un espace ou une tabulation :
Code BASH :
<filesystem> <mnt> <type> <options> <dump> <pass>
Je vais reprendre la ligne de mon exemple pour décrire à quoi sert chaque option :
Code BASH :
UUID=fd0587f2-d0d0-404c-b4c3-aa358b8dacd6/ext4noatime0 1
Première colonne
La première colonne indique le nom du périphérique ou les autres moyens de localiser la partition ou la source de données.
Ici, elle est repérée grâce à son UUID (chose commune de nos jours)
Mais il est possible de renseigner la partition concernée de plusieurs façons :
- /dev/sda1(Par le nom du périphérique)
- UUID=ffffffff-ffff-ffff-ffff-ffffffffffff (Par le UUID)
- LABEL=root (Par son LABEL)
Deuxième colonne
La deuxième colonne indique le point de montage dans l’arborescence du système de fichiers global.
Dans mon exemple, /.
Les valeurs peuvent prendre n'importe quel dossier le l'arborescence
Troisième colonne
La troisième colonne indique le type de système de fichiers ou l’algorithme utilisé pour l’interpréter.
Dans mon exemple, c'est ext4.
Parmi ces valeurs, on peut rencontrer : ext2, ext3, ext4, reiserfs, xfs, jfs, smbfs, btrfs, vfat, ntfs, swap
Quatrième colonne
La quatrième colonne définit des options particulières pour les systèmes de fichier. Certaines options sont pour le système de fichiers lui même. Les options indiquées dans le fichier fstab sont les mêmes que celles de la commande mount. Les options les plus répandues sont :
- defaults - paramètres de montage par défaut (équivalent à rw,suid,dev,exec,auto,nouser,async).
- auto - le système de fichiers sera monté automatiquement au démarrage, ou quand la commande 'mount -a' sera joué.
- noauto - le système de fichiers est monté que quand on lui demande de le faire.
- nofail - si la partition n'est pas disponible au démarrage, elle n'est pas montée et ne bloque pas le démarrage
- rw - monte le système de fichiers en lecture et en écriture.
- ro - monte le système de fichiers en lecture seulement.
- relatime - mettre à jour la date d'accès sur l'inode par rapport au modification ou au changement de date.
- noatime - ne pas mettre à jour la date d'accès sur l'inode pour le système de fichier
- user - permet à n'importe quel utilisateur de monter le système de fichiers (cela implique noexec,nosuid,nodev).
- nouser - autorise seulement le compte root à monter le fichier système (par défaut).
- sync - Les entrées/sorties (I/O) devraient être faites de manière synchrone.
- async - Les entrées/sorties (I/O) devraient être faites de manière asynchrone.
- suid - autorise les opérations sur les bits suid et sgid. Le plus souvent cela permet d'autoriser un utilisateur sur un ordinateur à exécuter un binaire avec une élévation temporaire des privilèges dans le but d'effectuer une tache spécifique.
- nosuid - bloque les opérations sur les bits suid et sgid.
- exec - autorise l'exécution de binaire qui sont sur cette partition (par défaut).
- noexec - n'autorise pas l'exécution de binaires sur le système de fichier.
- acl- autorise la gestion des acl sur cette partition.
Il est possible de spécifier plusieurs options et de les séparer par une virgule.
Dans mon exemple, si je veux en plus de noatime spécifier acl :
Code BASH :
UUID=fd0587f2-d0d0-404c-b4c3-aa358b8dacd6/ext4noatime,acl0 1
Cinquième colonne
Cette colonne a toujours été mystérieuse pour moi. D'après quelques documentations sur Internet j'en suis arrivé à l'utilisation suivante :
Cette valeur est utilisée par l'utilitaire dump pour décider quand faire des sauvegardes. Quand il est installé, dump vérifie le chiffre inscrit et décide si le système de fichiers doit être sauvegardé. Les valeurs possibles sont 0 et 1. Si 0, dump va ignorer le système de fichier, si 1, dump fera une sauvegarde. La plupart des utilisateurs n'auront pas dump d'installé, ils pourront donc inscrire 0 dans le champ <dump>.
Sixième colonne
Cette colonne indique la priorité de vérification du système de fichiers par l'utilitaire fsck.
fsck lit le chiffre et détermine dans quel ordre les systèmes de fichiers vont être vérifiés. Le champ peut prendre les valeurs 0,1 et 2. Le système de fichiers root devra avoir la priorité la plus haute : 1, tout les autres systèmes que vous voulez vérifier devront avoir un 2. Les systèmes de fichiers avec un 0 ne seront pas vérifiés par l'utilitaire fsck.