Journaling-Dateisystem
aus Wikipedia, der freien Enzyklopädie
Ein Journaling-Dateisystem unterscheidet sich durch zwei Faktoren von einem herkömmlichen Dateisystem. So wird ein Journal über die gerade geänderten Daten geführt und die zu ändernden Daten behalten ihre Gültigkeit, bis der Schreibvorgang beendet ist. Diese Funktion fällt beim störungsfreien Betrieb eines Computers, von einer Verminderung der Leistung abgesehen, nicht auf, zeigt sich aber bei Systemabstürzen. So prüft das Betriebssystem nach einem Absturz nicht das ganze Dateisystem, sondern lediglich die zu diesem Zeitpunkt geöffneten Dateien und repariert sie gegebenenfalls. Speziell bei großen Festplatten mit Partitionsgrößen über 100 GByte ergibt sich dadurch eine beträchtliche Zeitersparnis beim Booten, da das Überprüfen dieser durchaus mehrere Stunden dauern kann.
Man unterscheidet zwischen Metadaten-Journaling und Full-Journaling. Während Metadaten-Journaling lediglich die Konsistenz des Dateisystems garantiert, wird beim Full-Journaling auch die Konsistenz der Dateiinhalte gewährleistet. Umgangssprachlich wird oft der allgemeine Begriff des Journaling verwendet, wenn eigentlich Metadaten-Journaling gemeint ist.
[Bearbeiten] Problematik von Dateisystemaktualisierungen
Ein Dateisystem speichert Informationen über Dateien und dateiähnliche Objekte (insbesondere Verzeichnisse), indem es einem Namen Daten zuordnet. Es gibt verschiedene Möglichkeiten, dies zu bewerkstelligen, und jedes Dateisystem benutzt teilweise ähnliche, aber nie vollständig identische Strukturen. Allen Dateisystemen gemeinsam ist aber, dass Veränderungen von Dateien (dazu gehören auch das Erstellen, Verschieben, Umbenennen oder Löschen) Schreiboperationen an mehreren Stellen auf dem Massenspeicher erfordern. Führt man die erste Schreiboperation aus, befindet sich das Dateisystem nicht mehr in einem konsistenten Zustand (es enthält Änderungen, aber noch nicht alle Änderungen; die Semantik dabei ist: Es wird davon ausgegangen, dass abgeschlossene Schreiboperationen die Datei von einem konsistenten Zustand in einen anderen überführt haben), schließt man den letzten Schreibvorgang ab, ist das Dateisystem wieder konsistent. Muss der Computer allerdings zwischenzeitlich neu gestartet werden (sei es wegen eines Absturzes, eines Stromausfalls, oder eines Betätigens des Reset-Tasters), so muss das Dateisystem erst aufwendig auf solche Fehler untersucht werden, bevor man wieder sicher damit arbeiten kann. Überspringt man solch einen Test, kann es bei folgenden Schreiboperationen zu schwerwiegenden Folgefehlern kommen, die im schlimmsten Falle bis zum Totalverlust aller Daten führen können.
[Bearbeiten] Funktion des Journalings
Das Journaling-Konzept wirkt dieser Problematik entgegen. Nehmen wir an, der Benutzer will eine Datei D aus dem Verzeichnis V1 ins Verzeichnis V2 verschieben. Dann müssen zwei Schreiboperationen durchgeführt werden: Zum einen muss der alte Eintrag auf D aus dem Verzeichnis V1 entfernt werden, zum anderen muss der neue Eintrag D in das Verzeichnis V2 hinzugefügt werden. Letzteres kann es erforderlich machen, dass das Verzeichnis V2 vergrößert wird, was dann noch weitere Veränderungen nach sich ziehen würde. Alle diese Änderungen werden nun nicht an den Stellen durchgeführt, wo sie eigentlich hin gehören, sondern sie werden zuerst in einem speziellen Bereich in das Dateisystem geschrieben, dem sogenannten Journal. Dort steht dann z. B. qualitativ:
- Entferne Eintrag D aus Verzeichnis V1
- Füge Eintrag D dem Verzeichnis V2 hinzu
Diese Vorgehensweise alleine ergibt allerdings noch nicht das gewünschte Ziel der Sicherheit gegen nicht vollständig durchgeführte Operationen, da hier wieder mitten in der Operation – vielleicht zufällig genau nach „Entferne Eintrag D aus Verzeichnis V1“ aber vor „Füge Eintrag D dem Verzeichnis V2 hinzu“ das System abstürzt. Daher muss das Journal von Zeit zu Zeit abgeschlossen werden. Dabei wird verzeichnet, wieviele Änderungen bis hier durchgeführt wurden, und es wird durch eine Prüfsumme sichergestellt, dass die Daten korrekt sind. Sinnvollerweise sollte also eine Verschiebeoperation mit dem Anlegen der Datei am neuen Ort beginnen, dann alle Daten kopieren und mit der Löschung des Verzeichniseintrags und somit auch der Freigabe des Festplattenplatzes auf dem Quelldatenträger beendet werden.
Ergänzung und Verwendung bei Apple Computern, zu HFS+ Journaling (Mac OS X Computer, Apple):
Beim Mac OS X ab Version 10.3.x gibt es während der Installation die Möglichkeit, das Schreibzyklusintervall festzulegen. Dieser Schreibzyklus lässt sich auch nach der Installation individuell festlegen, indem man nach der Installation einen Zyklus nach einer von selbst gesetzten Zeit aktiviert. D. h. Im Falle eines Systemfehlers, den man verursacht hat, kann man die aktuelle Sitzung verwerfen und nicht auf die Festplatte schreiben lassen, oder aber den Schreibzyklus vor der Ausführung direkt verwerfen. Das ist z. B. wichtig, wenn man festgelegt hat, dass der Aktualisierungszyklus auf 30min festgelegt wurde. Das bietet Vorteile und Nachteile.
Vorteile:
- Bei einem Hackerangriff, werden die Änderungen nicht aktiv, wenn man beim Herunterfahren die Änderungen verwirft. Das gilt z. B. auch für fehlerhafte Installationen
- Diese Option bietet direkte Kontrolle auf die Speicherprozesse
- Nach Konfiguration einfach zu bedienen
- Ist direkt über Systemeinstellungen konfigurierbar
- Beim Herunterfahren erscheint die Möglichkeit die Sitzung zu übernehmen oder zu verwerfen
Nachteile:
- Verpassen des Schreibzyklus kann zu ungewollten Datenänderungen führen
- Systemabstürze führen zum Verlust der Änderungen, die nach dem letzten Zyklus bevorstünden
- Die Zyklusvarianz muss während der Installation der Systemsoftware eingespielt werden. Bei der Standardkonfiguration ist die Zyklusmöglichkeit nicht enthalten.
- Aktivierung der Schreibzyklusfunktion ist nur in Verbindung mit der „Firmware“ bei gleichzeitiger Systeminstallation möglich, und somit für den normalen Anwender schwierig zu bewerkstelligen.
[Bearbeiten] Eine Auswahl von Journaling-Dateisystemen und ihrer Verfügbarkeit
- ReiserFS: Linux
- ext3/ext4: Linux
- XFS: Linux und IRIX
- JFS/JFS2: Linux, AIX und OS/2
- NTFS: Microsoft Windows
- HFSJ: erweiterte Variante von HFS inklusive Mac OS X
- advfs: Tru64
- BeFS: BeOS
- FFS: BSD
- SFS (SmartFilesystem), PFS (Professional-File-System): Amiga
- VxFS: AIX, HP-UX, Linux und Solaris
- ZFS: Solaris
Die unter BSD verwendeten UFS-Dateisysteme verwenden eine Technik namens Softupdates, die einen in Bezug auf die Zielsetzung vergleichbaren Ansatz verfolgt.
Journaling-Dateisysteme sind mittlerweile Standard und unter vielen freien, kommerziellen und alternativen Betriebssystemen verfügbar.