Network file system

Un article de Wikipédia, l'encyclopédie libre.

Pour les articles homonymes, voir NFS.
Pile de protocoles
Application
Présentation
Session
Transport
Réseau
Liaison de données
Physique
Modèle OSI

Le système de fichiers en réseau (Network File System ou NFS) est un protocole développé par Sun Microsystems qui permet à un ordinateur d'accéder à des fichiers via un réseau.

Ce système de fichiers en réseau permet de partager des données principalement entre systèmes UNIX. Des implémentations existent pour Macintosh ou Microsoft Windows.

NFS est compatible avec IPv6 sur la plupart des systèmes.[1]

Sommaire

[modifier] NFS versions 1,2,3

Les versions 1 et 2 sont non sécurisées, prévues pour fonctionner sur UDP.

La version 3 est étendue pour prendre en charge TCP.

À ce stade la gestion de la sécurité reste élémentaire et souffre d'importantes lacunes. Le système est sans état (stateless) et ne permet pas la reprise sur incidents.

[modifier] NFSv4

Inspirée de AFS la version 4 du protocole marque une rupture totale avec les versions précédentes. L'ensemble du protocole est repensé, et les codes sont réécrits. Il s'agit d'un système de fichier objet.

Imaginée pour répondre aux besoins d'internet, NFSv4 intègre :

  • Une gestion totale de la sécurité :
    • négociation du niveau de sécurité entre le client et le serveur
    • sécurisation simple, support de kerberos5, certificats SPKM et LIPKEY
    • Chiffrement des communications possible (kerberos 5p par exemple)
  • Support accru de la montée en charge :
    • Réduction du trafic par groupement de requêtes (compound)
    • Délégation (le client gère le fichier en local)
  • Systèmes de maintenances simplifiés :
    • Migration : le serveur NFS est migré de la machine A vers la machine B de manière transparente pour le client
    • Réplication : le serveur A est répliqué sur la machine B
  • Reprise sur incidents
    • La gestion de la reprise sur incident est intégrée du côté client et du côté serveur.
  • Compatibilité :
    • NFSv4 peut être utilisée sous Unix et maintenant également sous MS-Windows
  • Support de plusieurs protocoles de transports (TCP, RDMA)

Cependant ces améliorations de NFSv4 rendent NFSv4 incompatible avec NFSv3. Notamment, la reprise sur incident et la délégation impliquent que NFSv4 soit un serveur à état (statefull), non compatible avec les précédentes versions. De plus, NFSv4 n'est pas prévue pour pouvoir utiliser le protocole UDP.

Pour toutes ces raisons il est hautement préférable d'utiliser NFSv4 plutôt que NFSv3, dans la mesure où une migration totale est possible.

[modifier] NFSv4.1

La version 4.1 de NFS est à l'état de RFC[2]. Cette version issue de NFSv4 est inspirée de pNFS et de LUSTRE, ainsi que des protocoles internet tels que Http. Elle tire parti de la conception objet du protocole. La notion de géométrie de fichier et celle de segments sont désormais abstraites : ils peuvent être parallélisés ou utiliser des chemins multiples vers les données. L'utilisation de fichier essentiellement creux est optimisée. Le transport de données est également abstrait, et est maintenant indépendant non seulement de TCP mais aussi de IP. La notion de session fait son apparition.

  • Délégation par répertoires
  • Sessions : la session d'un utilisateur peut être interrompue et rétablie.
    • Simplification du support du failover.
    • Abstraction des protocoles de transports, indépendance de IP et de TCP.
  • Abstraction de la géométrie de fichiers :
    • Parallélisation des accès aux fichiers (Stripping)

Bien que les RFC de la versions 4.1 ne soient pas stabilisés, l'implémentation du protocole a déjà débuté sur la plupart des solutions Unix.

[modifier] Références

  1. Dont Linux (client et serveur), Solaris, AIX
  2. Septembre 2006

[modifier] Voir aussi

[modifier] Articles connexes

Sytèmes de fichiers réseaux non parallèles:

Systèmes de fichiers parallélisés :

  • Portmap : daemon nécessaire pour que NFSv2 et NFSv3 fonctionne

[modifier] Liens externes