Gelegentlich benötigt man ein Verzeichnis (oder ein Filesystem) an einer anderen Stelle im Filesystem oder vielleicht sogar an mehreren verschiedenen Stellen im Filesystem. Anstatt das Problem mit symbolischen Links zu lösen, kann man elegant das namefs-Filesystem zum Einsatz bringen.
In folgenden Beispie wird /data/in an anderer Stelle benötigt:
# ls -l /data/in total 16 -rw-r--r-- 1 root system 554 May 14 16:10 file1 -rw-r--r-- 1 root system 381 May 14 16:10 file2 # ls -l /other/place total 0 #
Mounten des Directories an die gewünschte Stelle /other/place:
# mount -v namefs /data/in /other/place # ls -l /other/place total 16 -rw-r--r-- 1 root system 554 May 14 16:10 file1 -rw-r--r-- 1 root system 381 May 14 16:10 file2 #
Der Mount mit dem namefs-Filesystem bietet zusätzlich die Möglichkeit Mount-Optionen anzugeben, die dann nur für das Verzeichnis gelten. Man kann damit z.B. ein Verzeichnis auch mit Direct-I/O Mounten, obwohl das ursprüngliche Verzeichnis nicht mit Direct-I/O gemountet wurde:
# mount -v namefs -o dio /data/in /other/place # mount node mounted mounted over vfs date options -------- --------------- --------------- ------ ------------ --------------- /dev/hd4 / jfs2 May 02 11:30 rw,log=/dev/hd8 ... /data/in /other/place namefs May 14 16:14 rw,dio #
Bei Zugriffen auf die Dateien unterhalb /other/place wird nun Direct-I/O verwendet, greift man aber über die „Originale“ unter /data/in zu, wird kein Direct-I/O verwendet!
Der Zugriff auf Dateien ist allerdings wie bei NFS auf das unterliegende physikalische Filesystem beschränkt. Dies läßt sich leicht anhand des Filesystems / demonstrieren. Wir mounten / per namefs unter /mnt und schauen uns /mnt/usr und /mnt/var an:
# mount -v namefs / /mnt # ls -l /mnt/usr /mnt/var /mnt/usr: total 0 lrwxrwxrwx 1 root system 11 Apr 17 07:49 lib -> /../usr/lib /mnt/var: total 0 #
Die Verzeichnisse sind leer bzw. enthalten einen symbolischen Link, /usr und /var sehen etwas anders aus!
Dies kann man natürlich auch ausnutzen, z.B. in Fällen bei denen interessante Daten übermountet wurden. Wir haben unterhalb von /home eine Datei abgelegt, bevor /dev/hd1 auf /home gemountet wurde. Über das gerade auf /mnt gemountet root-Filesystem kann man auf diese übermounteten Daten zugreifen:
# ls -l /mnt/home total 0 -rw-r--r-- 1 root system 0 May 14 17:48 overmounted_file #
Eine weitere Anwendung besteht darin ein Verzeichnis vor überschreiben zu schützen. Wir demonstrieren dies am Verzeichnis /data mit 2 Test-Dateien:
# ls -l /data total 16 -rw-r--r-- 1 root system 554 May 14 17:52 file1 -rw-r--r-- 1 root system 381 May 14 17:52 file2 # cp /etc/hosts /data # ls -l /data total 24 -rw-r--r-- 1 root system 554 May 14 17:52 file1 -rw-r--r-- 1 root system 381 May 14 17:52 file2 -rw-r--r-- 1 root system 2075 May 14 17:54 hosts #
Überschreiben oder Ändern von Daten ist aktuell noch möglich, wie das erfolgreiche cp-Kommando zeigt. Jetzt schützen wir die Daten, indem wir einen Mount mit dem namefs-Filesystem und der Option ro (Read-Only) durchführen:
# mount -v namefs -o ro /data /data # cp /etc/services /data cp: /data/services: Read-only file system #
Die Daten können offensichtlich nicht mehr geändert werden. Hier haben wir /data mit einer Read-only Version von sich selbst übermountet!
Mounts mit dem Pseudo-Filesystem namefs können nicht nur auf jfs2-Filesystemen, sondern auch für NFS-Filesysteme oder das procfs-Filesystem durchgeführt werden.
Als Letztes zeigen wir noch das Mounten einer Datei an einer anderen Stelle des Filesystems. Wir wollen die Datei /etc/hosts über den Namen /hosts verfügbar machen. Dazu legen wir zunächst eine leere Datei /hosts an und mounten dann die Datei /etc/hosts über diese leere Datei:
# touch /hosts # ls -l /hosts -rw-r--r-- 1 root system 0 May 14 17:59 /hosts # mount -v namefs /etc/hosts /hosts # ls -l /hosts -rw-rw-r-- 1 root system 2075 Apr 26 10:47 /hosts #
Vor dem Mount ist /hosts 0 Bytes groß, nach dem Mount 2075 Bytes!
Das namefs-Filesystem bietet also einige interessante Möglichkeiten, die bei einige Problemstellungen nützlich sein können.