<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Network_File_System</id>
	<title>Network File System - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Network_File_System"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Network_File_System&amp;action=history"/>
	<updated>2026-05-17T03:04:31Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Network_File_System&amp;diff=68006&amp;oldid=prev</id>
		<title>178.15.120.59: /* Weblinks */</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Network_File_System&amp;diff=68006&amp;oldid=prev"/>
		<updated>2025-05-22T06:00:06Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;Weblinks&lt;/span&gt;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;{| class=&amp;quot;float-right&amp;quot; style=&amp;quot;margin-top:0; text-align:center;&amp;quot; cellspacing=&amp;quot;3&amp;quot;&lt;br /&gt;
|+ &amp;#039;&amp;#039;&amp;#039;NFS im [[OSI-Schichtenmodell]]&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
|style=&amp;quot;background:#FFCC99&amp;quot;| &amp;#039;&amp;#039;&amp;#039;Anwendung&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
|colspan=&amp;quot;4&amp;quot; style=&amp;quot;background:#9999FF&amp;quot;| &amp;#039;&amp;#039;&amp;#039;NFS&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
|style=&amp;quot;background:#FFCC99&amp;quot;| &amp;#039;&amp;#039;Darstellung&amp;#039;&amp;#039;&lt;br /&gt;
|colspan=&amp;quot;4&amp;quot; style=&amp;quot;background:#EEEEFF&amp;quot;| &amp;#039;&amp;#039;&amp;#039;[[External Data Representation|XDR]]&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
|style=&amp;quot;background:#FFCC99&amp;quot;| &amp;#039;&amp;#039;Sitzung&amp;#039;&amp;#039;&lt;br /&gt;
|colspan=&amp;quot;4&amp;quot; style=&amp;quot;background:#EEEEFF&amp;quot;| &amp;#039;&amp;#039;(Sun-)&amp;#039;&amp;#039; &amp;#039;&amp;#039;&amp;#039;[[Remote Procedure Call|RPC]]&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
|style=&amp;quot;background:#FFCC99&amp;quot;| &amp;#039;&amp;#039;Transport&amp;#039;&amp;#039;&lt;br /&gt;
|colspan=&amp;quot;2&amp;quot; style=&amp;quot;background:#EEEEFF&amp;quot;| &amp;#039;&amp;#039;&amp;#039;([[User Datagram Protocol|UDP]])&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
|colspan=&amp;quot;2&amp;quot; style=&amp;quot;background:#EEEEFF&amp;quot;| &amp;#039;&amp;#039;&amp;#039;[[Transmission Control Protocol|TCP]]&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
|style=&amp;quot;background:#FFCC99&amp;quot;| &amp;#039;&amp;#039;Netzwerk&amp;#039;&amp;#039;&lt;br /&gt;
|colspan=&amp;quot;4&amp;quot; style=&amp;quot;background:#EEEEFF&amp;quot;| &amp;#039;&amp;#039;&amp;#039;[[Internet Protocol|IP]] ([[IPv4]], [[IPv6]])&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
|-&lt;br /&gt;
|style=&amp;quot;background:#FFEEBB&amp;quot;| &amp;#039;&amp;#039;Netzzugang&amp;#039;&amp;#039;&lt;br /&gt;
|style=&amp;quot;background:#EEEEEE&amp;quot;| [[Ethernet]]&lt;br /&gt;
|style=&amp;quot;background:#EEEEEE&amp;quot;| [[Token Ring|Token&amp;lt;br /&amp;gt;Ring]]&lt;br /&gt;
|style=&amp;quot;background:#EEEEEE&amp;quot;| [[Fiber Distributed Data Interface|FDDI]]&lt;br /&gt;
|style=&amp;quot;background:#EEEEEE&amp;quot;| …&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Das &amp;#039;&amp;#039;&amp;#039;Network File System&amp;#039;&amp;#039;&amp;#039; (&amp;#039;&amp;#039;&amp;#039;NFS&amp;#039;&amp;#039;&amp;#039;, auch &amp;#039;&amp;#039;Network File Service&amp;#039;&amp;#039;) ist ein von [[Sun Microsystems]] entwickeltes [[Netzwerkprotokoll|Protokoll]], das den Zugriff auf [[Datei]]en über ein [[Rechnernetz|Netzwerk]] ermöglicht. Dabei werden die Dateien nicht wie z.&amp;amp;nbsp;B. bei [[File Transfer Protocol|FTP]] übertragen, sondern die Benutzer können auf Dateien, die sich auf einem entfernten Rechner befinden, so zugreifen, als ob sie auf ihrer lokalen [[Laufwerk (Computer)|Festplatte]] abgespeichert wären.&lt;br /&gt;
&lt;br /&gt;
Bei diesem [[Unix]]-Netzwerkprotokoll handelt es sich um einen [[Internet]]-[[Standard]] (&amp;lt;nowiki&amp;gt;RFC&amp;amp;nbsp;1094&amp;lt;/nowiki&amp;gt;,&amp;lt;ref&amp;gt;{{RFC-Internet |RFC=1094 |Titel=NFS Version 2 Protocol Specification |Datum=1989 |Updated=3010}}&amp;lt;/ref&amp;gt; &amp;lt;nowiki&amp;gt;RFC&amp;amp;nbsp;1813&amp;lt;/nowiki&amp;gt;,&amp;lt;ref&amp;gt;{{RFC-Internet |RFC=1813 |Titel=NFS Version 3 Protocol Specification |Datum=1995 |Updated=3010}}&amp;lt;/ref&amp;gt; &amp;lt;nowiki&amp;gt;RFC&amp;amp;nbsp;3530&amp;lt;/nowiki&amp;gt;,&amp;lt;ref&amp;gt;{{RFC-Internet |RFC=3530 |Titel=Network File System (NFS) version 4 Protocol |Datum=2003 |Updated=7530}}&amp;lt;/ref&amp;gt; &amp;lt;nowiki&amp;gt;RFC&amp;amp;nbsp;7530&amp;lt;/nowiki&amp;gt;&amp;lt;ref name=&amp;quot;RFC7530&amp;quot; /&amp;gt;), der auch als verteiltes [[Dateisystem]] ({{enS|distributed file system}}) bezeichnet wird.&lt;br /&gt;
&lt;br /&gt;
Die Entsprechung zu NFS heißt unter Windows- und [[OS/2]]-Umgebungen [[Server Message Block]] (SMB).&lt;br /&gt;
Während sich bei SMB der Benutzer authentifiziert, authentisiert NFSv3 den Client-Rechner, erst NFSv4 ermöglicht Benutzerauthentifikation. NFS-Dienste sind auch auf [[Microsoft Windows|Microsoft-Windows]]-[[Server]]n verfügbar, wodurch UNIX-[[Workstation]]s Zugang zu deren Dateien erhalten können, allerdings wird in gemischten Umgebungen meist SMB mit [[Samba (Software)|Samba]] auf Unixseite verwendet.&lt;br /&gt;
&lt;br /&gt;
NFS arbeitet auf dem [[Netzwerkprotokoll]] [[Internet Protocol|IP]] ursprünglich zusammen mit dem [[Zustandslosigkeit|zustandslosen]] [[User Datagram Protocol|UDP]]. Mittlerweile gibt es aber auch NFS über [[Transmission Control Protocol|TCP]]. NFSv4 arbeitet nur mit TCP und benötigt nur noch einen Port (2049), was den Betrieb durch [[Firewall]]s erleichtert. NFSv4 wurde maßgeblich durch die [[Internet Engineering Task Force|IETF]] entwickelt, nachdem Sun die Entwicklung abgegeben hatte.&amp;lt;ref&amp;gt;{{Internetquelle |url=https://datatracker.ietf.org/wg/nfsv4/charter/ |titel=Network File System Version 4 (nfsv4) |hrsg=[[Internet Engineering Task Force|IETF]] |sprache=en |abruf=2021-03-04}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Schematischer Ablauf der Datenübertragung ==&lt;br /&gt;
Im Folgenden ist der prinzipielle Ablauf einer NFS-Kommunikation des alten zustandslosen NFS bis einschließlich Version&amp;amp;nbsp;3 beschrieben. Szenario: Ein Nutzer des Client-Rechners möchte ein entferntes Verzeichnis &amp;#039;&amp;#039;(/directory)&amp;#039;&amp;#039; öffnen und eine darin befindliche Datei &amp;#039;&amp;#039;(test)&amp;#039;&amp;#039; anzeigen lassen.&lt;br /&gt;
&lt;br /&gt;
Damit ein Datenaustausch zwischen NFS-Server und -Client stattfinden kann, muss der NFS-Server gestartet und beim [[Portmapper]] registriert sein.&lt;br /&gt;
&lt;br /&gt;
# [[Client]] kontaktiert Portmapper auf Port 111 und fragt nach dem [[Port (Netzwerkadresse)|Port]] des [[Mounten|Mount]]-[[Daemon]]s (mountd)&lt;br /&gt;
# Portmapper gibt Portnummer für mountd heraus. Typischerweise ist das 694.&lt;br /&gt;
# Client kontaktiert mountd und fragt nach einem [[Filehandle]] für &amp;#039;&amp;#039;/directory&amp;#039;&amp;#039;, des vom Clienten zu mountenden Verzeichnisses des Servers.&lt;br /&gt;
# mountd gibt ein &amp;#039;&amp;#039;Filehandle 0&amp;#039;&amp;#039; als &amp;#039;&amp;#039;root&amp;#039;&amp;#039;-Filehandle für das zu mountende Verzeichnis des Servers zurück&lt;br /&gt;
# Client kontaktiert Portmapper und fragt nach dem Port für NFS (nfsd). Typischerweise ist das 2049.&lt;br /&gt;
# Portmapper gibt Portnummer für nfsd heraus&lt;br /&gt;
# Client führt &amp;#039;&amp;#039;LOOKUP&amp;#039;&amp;#039;-[[Prozedur (Programmierung)|Prozedur]] aus mit den Parametern &amp;#039;&amp;#039;Filehandle&amp;amp;nbsp;0&amp;#039;&amp;#039; und dem Dateinamen &amp;#039;&amp;#039;(test)&amp;#039;&amp;#039;&lt;br /&gt;
# nfsd gibt &amp;#039;&amp;#039;Filehandle 1&amp;#039;&amp;#039; für Datei &amp;#039;&amp;#039;(test)&amp;#039;&amp;#039; heraus&lt;br /&gt;
# Client führt &amp;#039;&amp;#039;READ&amp;#039;&amp;#039;-Prozedur aus mit dem Parameter &amp;#039;&amp;#039;Filehandle&amp;amp;nbsp;1&amp;#039;&amp;#039;&lt;br /&gt;
# nfsd gibt Inhalt der Datei &amp;#039;&amp;#039;(test)&amp;#039;&amp;#039; zurück (Daten)&lt;br /&gt;
&lt;br /&gt;
== Design der frühen Versionen des Systems ==&lt;br /&gt;
Ein Programm greift auf das Dateisystem über [[Systemaufruf]]e zu. Unter [[Unix]] sind die wichtigsten Systemaufrufe:&lt;br /&gt;
* &amp;#039;&amp;#039;open&amp;#039;&amp;#039;, &amp;#039;&amp;#039;close&amp;#039;&amp;#039; – Öffnen und Schließen einer Datei&lt;br /&gt;
* &amp;#039;&amp;#039;read&amp;#039;&amp;#039;, &amp;#039;&amp;#039;write&amp;#039;&amp;#039; – Lesen und Schreiben&lt;br /&gt;
* &amp;#039;&amp;#039;create&amp;#039;&amp;#039;, &amp;#039;&amp;#039;unlink&amp;#039;&amp;#039; – Erzeugen und Löschen&lt;br /&gt;
* &amp;#039;&amp;#039;mkdir&amp;#039;&amp;#039;, &amp;#039;&amp;#039;rmdir&amp;#039;&amp;#039; – Erzeugen und Löschen eines Verzeichnisses&lt;br /&gt;
* &amp;#039;&amp;#039;readdir&amp;#039;&amp;#039; – Lesen von Verzeichniseinträgen&lt;br /&gt;
&lt;br /&gt;
Ein Netzwerkdateisystem muss diese Aufrufe in Netzwerkpakete verpacken und an einen [[Server]] senden. Dieser antwortet dann mit der entsprechenden Information oder einem Fehler.&lt;br /&gt;
&lt;br /&gt;
Die Entwickler von Sun Microsystems entschieden sich zunächst für ein [[Remote Procedure Call|Remote-Procedure-Call]]-Modell. [[External Data Representation|XDR]] setzt die Parameter des &amp;#039;&amp;#039;RPCs&amp;#039;&amp;#039; in ein maschinenunabhängiges Format um, die Zugriffe werden dann über den RPC Mechanismus wie ein normaler Unterprogrammaufruf behandelt.&lt;br /&gt;
&lt;br /&gt;
Die Systemaufrufe werden aber nicht direkt in RPC-Aufrufe umgesetzt, da dann eine über &amp;#039;&amp;#039;open&amp;#039;&amp;#039; geöffnete Datei auch auf dem Server geöffnet werden müsste. Bei vielen Clients wären die Server dann schnell überlastet, da die Maschinen Mitte der 1980er-Jahre noch relativ wenig Speicher hatten. Die Aufgaben des Servers wurden daher so einfach wie möglich gehalten, der Server merkt sich keine Dateiinformationen zwischen zwei RPC-Aufrufen. Er ist also zustandslos.&lt;br /&gt;
&lt;br /&gt;
Statt &amp;#039;&amp;#039;open&amp;#039;&amp;#039; wird ein &amp;#039;&amp;#039;lookup&amp;#039;&amp;#039;-Aufruf implementiert. Dieser liefert ein Datei-„Handle“, das die [[Inode]]nummer und die Gerätenummer des Massenspeichers auf dem Server enthält. Über dieses Handle kann eine Datei auf dem Server eindeutig identifiziert werden. Unter Unix steht über diese beiden Nummern die Dateiinformation effizient ohne aufwändige Suche eindeutig zur Verfügung.&lt;br /&gt;
&lt;br /&gt;
Die weiteren Aufrufe wie &amp;#039;&amp;#039;read&amp;#039;&amp;#039; oder &amp;#039;&amp;#039;write&amp;#039;&amp;#039; müssen stets ein Offset übergeben, so dass der Server auch hier ohne Kenntnis früherer Operation die gewünschte Information eindeutig liefern kann.&lt;br /&gt;
&lt;br /&gt;
Weitere Eigenschaften des Protokolls sind&lt;br /&gt;
* nur kurze [[Cache]]zeiten (wenige Sekunden) für Verzeichnisinformationen und Dateiattribute&lt;br /&gt;
* kein Datencache&lt;br /&gt;
* Verwendung des verbindungslosen User Datagram Protocols ([[User Datagram Protocol|UDP]]) optional [[Transmission Control Protocol|TCP]] (NFSv4 nur TCP)&lt;br /&gt;
* Lock- und Mount-Operationen über zusätzliche Hilfsprotokolle&lt;br /&gt;
* Verwendung von Unix-Dateiattributen (zum Beispiel Benutzer-&amp;#039;&amp;#039;uid&amp;#039;&amp;#039;)&lt;br /&gt;
&lt;br /&gt;
Wegen des einfachen Designs läuft NFS in normalen Umgebungen gut:&lt;br /&gt;
* lokales Netzwerk mit kurzen [[Antwortzeit]]en&lt;br /&gt;
* Ausführen von Programmen über das lokale Netzwerk&lt;br /&gt;
* Normale Benutzeraktivitäten (Editieren, Programme übersetzen)&lt;br /&gt;
* Server mit relativ wenig Arbeitsspeicher&lt;br /&gt;
&lt;br /&gt;
Weniger gut ist das Verhalten bei&lt;br /&gt;
* gemeinsamer Nutzung von Dateien&lt;br /&gt;
* Verwendung über das Internet (lange Antwortzeiten, geringe Sicherheit)&lt;br /&gt;
* Verwendung von Firewalls (UDP, kein fester Port wegen &amp;#039;&amp;#039;Portmapper&amp;#039;&amp;#039;) (Unter NFSv4 kein Problem mehr; jegliche Kommunikation läuft über Port 2049/TCP)&lt;br /&gt;
&lt;br /&gt;
Das Protokoll wurde Ende der 1980er-Jahre entwickelt. Auch teure [[Workstation]]s hatten zu dieser Zeit nur wenige [[Mebibyte]]s Arbeitsspeicher, typisch etwa 4 bis 8&amp;amp;nbsp;[[Mebibyte|MiB]]. Ein NFS-Server kann auf solchen Maschinen aufgrund des Designs trotzdem effizient betrieben werden.&lt;br /&gt;
&lt;br /&gt;
Wegen des zustandslosen Servers kann dieser ohne Datenverlust heruntergefahren und neu gestartet werden. Programme stürzen nicht ab und Benutzer müssen dann einfach warten, bis der Server wieder verfügbar ist.&lt;br /&gt;
&lt;br /&gt;
== Festplattenlose Arbeitsrechner ==&lt;br /&gt;
[[Arbeitsrechner]] (Workstations) können über NFS ganz ohne Festplatte betrieben werden.&lt;br /&gt;
Das Betriebssystem und die Betriebsparameter können über Protokolle wie [[Bootstrap Protocol|BOOTP]] und [[Trivial File Transfer Protocol|TFTP]] geladen werden. Ein spezieller Kernel (z.&amp;amp;nbsp;B. Linux) kann dann über NFS bereits auf das Root-Laufwerk unter Unix zugreifen. Spezielle plattenlose Arbeitsrechner &amp;#039;&amp;#039;([[Diskless-Workstation|diskless workstations]])&amp;#039;&amp;#039; wurden von der Firma Sun in den 1990er-Jahren angeboten.&lt;br /&gt;
&lt;br /&gt;
Vorteile sind ein verringerter Wartungsaufwand, gemeinsame Nutzung von Speicherplatz sowie einfachere und preiswerte Client-Workstations ([[Thin Client]]s). Bei vielen Clients wird der Server jedoch stark belastet, außerdem sind die Zugriffe über Netzwerk in den meisten Fällen langsamer.&lt;br /&gt;
&lt;br /&gt;
== PC-NFS ==&lt;br /&gt;
Sun und andere Firmen boten in den 1990er Jahren auch NFS-Clientsoftware für PCs unter [[Microsoft Windows|Windows]] an, das PC-NFS. Der Server musste weiterhin eine Unix-Workstation sein. Bis [[Windows for Workgroups]] war der Netzwerkzugriff unter Windows nicht Teil des Betriebssystems. In Unix-Umgebungen wurde der Einsatz von PCs dadurch wesentlich erleichtert.&lt;br /&gt;
&lt;br /&gt;
PC-NFS musste mit den unterschiedlichen Konzepten des DOS/Windows-Systems kämpfen. Die damaligen Windows-Versionen erlaubten nur Dateinamen mit bis zu acht Zeichen sowie eine drei Zeichen lange Erweiterung, die durch einen Punkt abgetrennt wurde (z.&amp;amp;nbsp;B. &amp;lt;code&amp;gt;AUTOEXEC.BAT&amp;lt;/code&amp;gt;, die sogenannte [[8.3]]-Notation), während Unix 255 Zeichen lange Pfadnamen erlaubte. Die Dateinamen unterschieden im Gegensatz zu DOS zwischen Groß- und Kleinschreibung. PC-NFS musste also zwischen den Dateinamenkonzepten übersetzen.&lt;br /&gt;
&lt;br /&gt;
Ein Unix-Dateiname &amp;#039;&amp;#039;file.txt&amp;#039;&amp;#039; erschien als &amp;lt;span style=&amp;quot;font-family:monospace;&amp;quot;&amp;gt;FILE.TXT&amp;lt;/span&amp;gt; unter Windows/DOS, während ein Dateiname &amp;#039;&amp;#039;Dokumentation.txt&amp;#039;&amp;#039; etwa in &amp;lt;span style=&amp;quot;font-family:monospace;&amp;quot;&amp;gt;DOKUME~1.TXT&amp;lt;/span&amp;gt; umgesetzt wurde.&lt;br /&gt;
&lt;br /&gt;
== NFS Version 4 ==&lt;br /&gt;
Die NFS Version 4 stellt eine Neuimplementierung dar, die neuere Erfordernisse berücksichtigt. Sie ist in &amp;lt;nowiki&amp;gt;RFC&amp;amp;nbsp;7530&amp;lt;/nowiki&amp;gt; standardisiert.&amp;lt;ref name=&amp;quot;RFC7530&amp;quot; /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Die Unix-Lastigkeit der frühen Versionen wird so weit wie möglich verringert. Die UNIX-Benutzer- und Gruppennummern werden durch eindeutigere Zeichenketten nach dem Muster nutzer@domain ersetzt. &amp;#039;&amp;#039;nutzer&amp;#039;&amp;#039; ist hierbei der Nutzername auf dem Server, &amp;#039;&amp;#039;domain&amp;#039;&amp;#039; ist die Domain des Servers, also der Teil des Hostnamens, der nicht den Server selbst identifiziert (&amp;#039;&amp;#039;srv.cs.example.net&amp;#039;&amp;#039; → &amp;#039;&amp;#039;cs.example.net&amp;#039;&amp;#039;). Durch die Kennung &amp;#039;&amp;#039;user@cs.example.net&amp;#039;&amp;#039; kann nun auf allen Rechnern der Domain &amp;#039;&amp;#039;cs.example.net&amp;#039;&amp;#039; der Nutzer eindeutig identifiziert werden, auch wenn der Nutzer &amp;#039;&amp;#039;user&amp;#039;&amp;#039; auf dem Server die Unix-User-ID 1050 hat und auf dem Client z.&amp;amp;nbsp;B. 1100. Dies führte bei früheren NFS-Versionen zu Problemen, wenn keine konsistente Nutzernummerierung eingehalten wurde. Für die Umsetzung der neuen NFS-Nutzernamen in (Unix-)Nutzer-IDs ist unter Linux zum Beispiel der Dienst &amp;#039;&amp;#039;rpc.idmapd&amp;#039;&amp;#039; (&amp;#039;&amp;#039;&amp;#039;&amp;#039;&amp;#039;ID&amp;#039;&amp;#039;&amp;#039; &amp;#039;&amp;#039;&amp;#039;map&amp;#039;&amp;#039;&amp;#039;per &amp;#039;&amp;#039;&amp;#039;d&amp;#039;&amp;#039;&amp;#039;aemon&amp;#039;&amp;#039;), unter [[FreeBSD]] der [[Daemon]] &amp;#039;&amp;#039;nfsuserd&amp;#039;&amp;#039; (&amp;#039;&amp;#039;&amp;#039;&amp;#039;&amp;#039;NFS&amp;#039;&amp;#039;&amp;#039; &amp;#039;&amp;#039;&amp;#039;user&amp;#039;&amp;#039;&amp;#039; &amp;#039;&amp;#039;&amp;#039;d&amp;#039;&amp;#039;&amp;#039;aemon&amp;#039;&amp;#039;) zuständig (sowohl für Server- als auch für Clientseite). Die Nutzernamen werden nur richtig zugeordnet, wenn Server und Client die gleiche Domain haben, ansonsten wird als Eigentümer &amp;#039;&amp;#039;nobody.nogroup&amp;#039;&amp;#039; angegeben.&lt;br /&gt;
&lt;br /&gt;
Da manche Dateisysteme keine effiziente Implementierung von eindeutigen [[Datei-Handle]]s ermöglichen, werden &amp;#039;&amp;#039;flüchtige&amp;#039;&amp;#039; [[Handle]]s eingeführt, die nur eine bestimmte Zeit zur Verfügung stehen. Unter Unix kann man Handles sehr einfach aus der Geräte- und [[Inode]]-Nummer konstruieren. Auch Dateisysteme, die nicht zwischen Groß- und Kleinschreibung unterscheiden, sowie benutzerdefinierte Dateiattribute werden jetzt unterstützt.&lt;br /&gt;
&lt;br /&gt;
Das [[Mounten|Mount]]- und [[Lock]]protokoll sind jetzt Bestandteil des Protokolls selbst, Hilfsprotokolle werden nicht mehr benötigt. Das Protokoll selbst läuft auf dem festen [[Transmission Control Protocol|TCP]]-Port &amp;#039;&amp;#039;2049&amp;#039;&amp;#039;, [[User Datagram Protocol|UDP]] wird nicht mehr unterstützt. Zwar liefen auch schon frühere Versionen auf diesem Port, die Hilfsprotokolle wurden vom RPC-Portmapper aber dynamisch zugeteilt. Die Verwendung von [[Firewall]]s bei NFS-Verbindungen wird durch diese Maßnahmen stark vereinfacht.&lt;br /&gt;
&lt;br /&gt;
Mehrere Anfragen können gebündelt werden &amp;#039;&amp;#039;(combined request)&amp;#039;&amp;#039;, sie werden dann vom Server ausgeführt und nur eine Antwort muss zurückgesendet werden. Das Protokoll kann damit effizient auch im Weitverkehrsbereich ([[Wide Area Network|WAN]]) eingesetzt werden, zum Beispiel zwischen verschiedenen Standorten einer Organisation.&lt;br /&gt;
&lt;br /&gt;
Verschlüsselung und [[Authentifizierung]] sind jetzt Teil der [[Spezifikation]]. Zwar war früher schon über Secure-RPC eine Verschlüsselung möglich. Das wurde nur selten genutzt, unter anderem, weil Secure-RPC nicht überall zur Verfügung stand.&lt;br /&gt;
&lt;br /&gt;
Der &amp;#039;&amp;#039;lookup&amp;#039;&amp;#039;-Aufruf wird durch &amp;#039;&amp;#039;open&amp;#039;&amp;#039; ersetzt, die Speicherung von Dateiinformationen wird dadurch möglich. Beispielsweise könnte die Schreib-/Leseposition auf dem Server verwaltet werden. Auch die gemeinsame Nutzung von Dateien wird besser unterstützt. Falls viele Clients eine Datei nur lesen, kann diese an alle Clients verliehen &amp;#039;&amp;#039;(leases)&amp;#039;&amp;#039; werden. Wenn ein Client eine Datei schreiben möchte, kann diese exklusiv verliehen werden.&lt;br /&gt;
&lt;br /&gt;
In Version 4.1 ist unter anderem paralleler Zugriff auf über mehrere Server verteilten Speicher hinzugefügt worden. Ab Version 4.2 im November 2016 werden serverseitige Kopien und Sparsefiles unterstützt.&lt;br /&gt;
&lt;br /&gt;
== Konfiguration in Unix-Systemen ==&lt;br /&gt;
Die NFS-Freigaben werden unter Unix serverseitig meist in der Datei /etc/exports festgelegt, die nach dem folgenden Schema aufgebaut ist. Dabei sind die Unterschiede zwischen Linux- und FreeBSD-Systemen zu beachten:&lt;br /&gt;
&lt;br /&gt;
 # Server-Adresse: 10.0.0.1&lt;br /&gt;
 # NFSv2, NFSv3:&lt;br /&gt;
 # Exportiert /path/to/directory an alle IPs von 10.0.0.0 bis 10.0.255.255,&lt;br /&gt;
 # und zwar zum Lesen/Schreiben (rw), asynchronem Zugriff (Daten werden&lt;br /&gt;
 # nicht sofort geschrieben) und auch von Ports über 1024 aus (insecure)&lt;br /&gt;
 #&lt;br /&gt;
 # Erreichbar als: 10.0.0.1:/path/to/directory&lt;br /&gt;
 #&lt;br /&gt;
 ### Linux-Systeme&lt;br /&gt;
 /path/to/directory 10.0.0.0/16(rw,async,insecure)&lt;br /&gt;
&lt;br /&gt;
 ### FreeBSD&lt;br /&gt;
 /path/to/directory        -network 10.0.0.0/16&lt;br /&gt;
&lt;br /&gt;
 # NFSv4:&lt;br /&gt;
 # Benötigt zur optimalen Funktion eine Freigabe mit der Option &amp;#039;&amp;#039;fsid=0&amp;#039;&amp;#039;.&lt;br /&gt;
 # Diese wird als root-Freigabe genutzt und ist als die Freigabe / zu&lt;br /&gt;
 # erreichen. Die anderen Freigaben liegen unterhalb davon. Ansonsten&lt;br /&gt;
 # ist optional eine Authentifizierung/Verschlüsselung mit [[Kerberos (Informatik)|Kerberos]]&lt;br /&gt;
 # möglich.&lt;br /&gt;
 #&lt;br /&gt;
 ### Linux-Systeme:&lt;br /&gt;
 # Erreichbar als 10.0.0.1:/&lt;br /&gt;
 # Wird diese Freigabe eingehängt, so sind alle darunterliegenden&lt;br /&gt;
 # Freigaben logischerweise zugänglich.&lt;br /&gt;
 /path/to/nfsv4/root 10.0.0.0/16(rw,async,insecure,&amp;#039;&amp;#039;&amp;#039;fsid=0&amp;#039;&amp;#039;&amp;#039;)&lt;br /&gt;
 # Erreichbar als 10.0.0.1:/export1&lt;br /&gt;
 /path/to/nfsv4/root/export1 10.0.0.0/16(rw,async,insecure)&lt;br /&gt;
&lt;br /&gt;
 ### FreeBSD&lt;br /&gt;
 # Root-Punkt spezifizieren (unter Linux der mit fsid=0 markierte Punkt)&lt;br /&gt;
 V4: /path/to/nfsv4/root    -network 10.0.0.0/16&lt;br /&gt;
 # Freigaben angeben&lt;br /&gt;
 /path/to/nfsv4/root/export1 -network 10.0.0.0/16&lt;br /&gt;
&lt;br /&gt;
Der Client kann eine Freigabe manuell mounten oder ggf. mit einem Eintrag in der Datei [[fstab]] automatisieren.&lt;br /&gt;
&lt;br /&gt;
Vielen aktuellen [[Linux-Distribution]]en liegen grafische Hilfswerkzeuge bei, um die Einbindung von NFS-Freigaben ins System zu vereinfachen, zum Beispiel das NFS-[[YaST]]-Plugin unter [[openSUSE]].&lt;br /&gt;
&lt;br /&gt;
== Sicherheit ==&lt;br /&gt;
&lt;br /&gt;
=== NFS Version 3 und früher ===&lt;br /&gt;
NFS wurde geschaffen, um in Unix-Netzen [[Dateisystem]]e über Rechnergrenzen hinweg zugänglich zu machen. Zur Zeit der Entwicklung von NFS waren solche Netze fast ausschließlich zentral verwaltet und die Rechner wurden zentral administriert, entsprechend wurde das Sicherheitskonzept gestaltet.&lt;br /&gt;
&lt;br /&gt;
Die Entwickler von NFS bei Sun Microsystems hatten ursprünglich vorgesehen, die Sicherheit als Aufgabe der RPC-Schicht zu implementieren. Dazu wird RPC durch Secure-RPC ersetzt. Die NFS-Protokolle selbst bleiben davon unberührt. Secure-RPC hat allerdings keine weite Verbreitung gefunden, die Verwendung ist auch nicht bei allen Implementierungen möglich.&lt;br /&gt;
&lt;br /&gt;
Ein NFS-Server ohne Secure-RPC exportiert Dateisysteme an bestimmte andere Rechner (von [[Root-Konto|root]] durch [[IP-Adresse]]n festgelegt), d.&amp;amp;nbsp;h. der root-User eines Clientrechners kann auf alle Dateien zugreifen, die der Server an den Client exportiert, unabhängig von deren Zugriffsrechten. Die Zugriffsrechte (der Benutzer) werden von NFS an den Client mitübertragen und vom Betriebssystem des jeweiligen Rechners ausgewertet und gegenüber den Benutzern durchgesetzt. Die Konsistenz der Benutzerdatenbank auf den beteiligten Rechnern wird dabei z.&amp;amp;nbsp;B. durch [[Network Information Service|NIS]] erreicht.&lt;br /&gt;
&lt;br /&gt;
Heute sind Rechnernetze häufig offen und nur bedingt zentral administriert, d.&amp;amp;nbsp;h. ein Angreifer kann relativ einfach entweder einen Rechner übernehmen, dem der NFS-Server vertraut, indem er ihn z.&amp;amp;nbsp;B. mit einem [[Live-System]] neu bootet oder einen zusätzlichen Laptop ins Netz hängt und die IP eines gerade nicht laufenden NFS-Clients annimmt. In beiden Fällen kann der Angreifer, da er auf seinem System Rootrechte hat, auf alle an den Client exportierten Dateien zugreifen, unabhängig von deren Zugriffsrechten. Somit ist NFS v3 ohne separat installiertes [[Kerberos (Protokoll)|Kerberos]] immer nur so sicher wie das Netz und die beteiligten Rechner.&lt;br /&gt;
&lt;br /&gt;
Mit der Server-Option &amp;#039;&amp;#039;root_squash&amp;#039;&amp;#039; (unter FreeBSD mit der in der entsprechenden Zeile anzugebenden Option &amp;lt;span style=&amp;quot;font-family:monospace;&amp;quot;&amp;gt;-maproot=&amp;lt;USER&amp;gt;&amp;lt;/span&amp;gt;) kann man das oben genannte Szenario unterbinden. Damit werden Zugriffe durch Benutzer mit der UID 0 (meist &amp;#039;&amp;#039;root&amp;#039;&amp;#039;) als Zugriffe des anonymen Benutzers (UID=65534) gewertet, der dann u.&amp;amp;nbsp;U. keinerlei Zugriffsrechte auf die freigegebenen Dateien hat. Ein Angreifer muss nun beim Verbinden so lange unterschiedliche UIDs ausprobieren, bis er die UID des Benutzers oder der Gruppe erwischt, die berechtigt ist. Da es nur &amp;lt;math&amp;gt;2^{16}&amp;lt;/math&amp;gt; (65536) UIDs gibt, bietet auch dieses Vorgehen keine echte Sicherheit.&lt;br /&gt;
&lt;br /&gt;
=== NFS Version 4 ===&lt;br /&gt;
NFSv4 löst dieses Problem, indem z.&amp;amp;nbsp;B. [[Kerberos (Informatik)|Kerberos]] nun Bestandteil des Protokolls ist und eine Authentifizierung der Benutzer ermöglicht. Zudem lässt sich mit einer ebenfalls optionalen Verschlüsselung auch die [[Vertraulichkeit]] sicherstellen.&lt;br /&gt;
&lt;br /&gt;
==== Verfügbare Sicherheitsmodi ====&lt;br /&gt;
Beim Verbinden kann einer der folgenden Mechanismen gewählt werden, um das Sicherheitsniveau (welches auch die Übertragungsgeschwindigkeit beeinflusst) festzulegen:&lt;br /&gt;
{| class=&amp;quot;wikitable&amp;quot;&lt;br /&gt;
|-&lt;br /&gt;
! Bezeichnung&lt;br /&gt;
! Bedeutung&lt;br /&gt;
! Mount-Option&lt;br /&gt;
|-&lt;br /&gt;
| sys&lt;br /&gt;
| Benutzeridentifikation erfolgt nach dem Schema von NFS3. Dies bietet sehr wenig Sicherheit.&lt;br /&gt;
| sec=sys&lt;br /&gt;
|-&lt;br /&gt;
| krb5&lt;br /&gt;
| Server und Client authentifizieren sich gegenseitig unter Benutzung der [[GSSAPI|GSS]]-Schnittstelle mittels Kerberos. Dies unterbindet das obige Angriffsszenario.&lt;br /&gt;
| sec=krb5&lt;br /&gt;
|-&lt;br /&gt;
| krb5i&lt;br /&gt;
| Zusätzlich wird die Integrität der übertragenen Daten sichergestellt. Dies verhindert eine Veränderung der Daten durch einen [[Man-in-the-Middle-Angriff|Man In The Middle]].&lt;br /&gt;
| sec=krb5i&lt;br /&gt;
|-&lt;br /&gt;
| krb5p&lt;br /&gt;
| Die Vertraulichkeit der übertragenen Daten wird zusätzlich zur Integrität gewährleistet. Dies verhindert ein Mitlesen durch einen Angreifer im Netzwerk.&lt;br /&gt;
| sec=krb5p&lt;br /&gt;
|}&lt;br /&gt;
&lt;br /&gt;
Eine Freigabe kann mehrere Mechanismen anbieten, aus denen der Client einen durch die Mount-Option auswählen kann.&lt;br /&gt;
&lt;br /&gt;
==== Alternative zu Kerberos ====&lt;br /&gt;
Allerdings wird des Öfteren bemängelt, dass mit Kerberos eine enorm komplexe und in einigen Umgebungen unmögliche Voraussetzung besteht. Daher wird anstelle der eingebauten Sicherheitsfunktionen von NFS oft eine zusätzliche Sicherheits-Schicht wie [[Transport Layer Security|TLS]] genutzt.&amp;lt;ref&amp;gt;{{Internetquelle |autor=Charles Fisher |url=https://www.linuxjournal.com/content/encrypting-nfsv4-stunnel-tls |titel=Encrypting NFSv4 with Stunnel TLS |werk=Linux Journal |hrsg=Slashdot Media, LLC |datum=2018-08-03 |sprache=en |abruf=2022-01-14}} {{&amp;quot; |Sprache=en |Text=The sec=krb5p option will encrypt NFSv4 traffic in a Kerberos realm, but requiring this infrastructure is inappropriate in hosted environments and is generally far from helpful. Basic access to symmetric cryptography does not and should not mandate such enormous baggage.}}&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Normen und Standards ==&lt;br /&gt;
Die Version 1.0 hat [[Sun Microsystems]] im Jahr 1984 erstellt.&amp;lt;ref name=&amp;quot;sun85&amp;quot;&amp;gt;{{Internetquelle |autor=Russel Sandberg, David Goldberg, Steve Kleiman, Dan Walsh, Bob Lyon |url=http://citeseerx.ist.psu.edu/viewdoc/summary?doi=10.1.1.14.473 |titel=Design and Implementation of the Sun Network Filesystem |hrsg=[[USENIX]] |datum=1985 |abruf=2023-07-20}}&amp;lt;/ref&amp;gt; Ab der Version 2.0 erfolgte die weitere Standardisierung als [[Request for Comments]]. Erst mit der Version 4.0 erfolgte der Wechsel vom Status Informational in Offizieller Standard. Die drei Versionen 4.0, 4.1 und 4.2 sind alle zugleich aktuelle Standards, deshalb gibt es seit 2017 auch Ergänzungen ohne Versionsnummer:&lt;br /&gt;
&lt;br /&gt;
a) Ursprünglicher Pfad von Version 2 zu Version 4.0:&lt;br /&gt;
* {{RFC-Internet |RFC=1094 |Titel=NFS Version 2 Protocol Specification |Datum=1989 |Updated=3010}}&lt;br /&gt;
* {{RFC-Internet |RFC=1813 |Titel=NFS Version 3 Protocol Specification |Datum=1995 |Updated=3010}}&lt;br /&gt;
* {{RFC-Internet |RFC=3010 |Titel=NFS Version 4 Protocol |Datum=2000 |Updated=3530}}&lt;br /&gt;
* {{RFC-Internet |RFC=3530 |Titel=Network File System (NFS) version 4 Protocol |Datum=2003 |Updated=7530}}&lt;br /&gt;
* {{RFC-Internet |RFC=7530 |Titel=NFS Version 4 Protocol Specification |Datum=2015}}&lt;br /&gt;
* {{RFC-Internet |RFC=7931 |Titel=NFSv4.0 Migration: Specification Update |Datum=2016}}&lt;br /&gt;
&lt;br /&gt;
b) Neuere Versionen 4.x&lt;br /&gt;
* {{RFC-Internet |RFC=5661 |Titel=Network File System (NFS) Version 4 Minor Version 1 Protocol |Datum=2010 |Kommentar=NFS 4.1}}&lt;br /&gt;
* {{RFC-Internet |RFC=7862 |Titel=Network File System (NFS) Version 4 Minor Version 2 Protocol |Datum=2016 |Kommentar=NFS 4.2}}&lt;br /&gt;
&lt;br /&gt;
c) Ergänzungen für 4.x&lt;br /&gt;
* {{RFC-Internet |RFC=8178 |Titel=Rules for NFSv4 Extensions and Minor Versions |Datum=2017}}&lt;br /&gt;
* {{RFC-Internet |RFC=8434 |Titel=Requirements for Parallel NFS (pNFS) Layout Types |Datum=2018}}&lt;br /&gt;
&lt;br /&gt;
== Weblinks ==&lt;br /&gt;
* {{Webarchiv |url=http://nfsv4.org/ |text=Projektseite |wayback=20110705014919}} (englisch)&lt;br /&gt;
* [http://nfs.sourceforge.net/ Linux-Implementierung von nfs] (englisch)&lt;br /&gt;
** {{Internetquelle&lt;br /&gt;
   |autor=Christopher Smith&lt;br /&gt;
   |url=http://nfs.sourceforge.net/nfs-howto/index.html&lt;br /&gt;
   |titel=Linux NFS-HOWTO&lt;br /&gt;
   |datum=2006-05-02&lt;br /&gt;
   |abruf=2010-12-16}}&lt;br /&gt;
* {{dmoz|Computers/Software/Operating_Systems/File_Systems/NFS/|NFS}} (englisch).&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references&amp;gt;&lt;br /&gt;
&amp;lt;ref name=&amp;quot;RFC7530&amp;quot;&amp;gt;&lt;br /&gt;
{{RFC-Internet |RFC=7530 |Titel=NFS Version 4 Protocol Specification |Datum=2015}}&lt;br /&gt;
&amp;lt;/ref&amp;gt;&lt;br /&gt;
&amp;lt;/references&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Freies Dateisystem]]&lt;br /&gt;
[[Kategorie:Internet-Dateiübertragungsprotokoll]]&lt;br /&gt;
[[Kategorie:Verteiltes Dateisystem]]&lt;/div&gt;</summary>
		<author><name>178.15.120.59</name></author>
	</entry>
</feed>