Journaling-Dateisystem - LinkFang.de





Journaling-Dateisystem


Ein Journaling-Dateisystem ist ein Dateisystem, das alle Änderungen vor dem eigentlichen Schreiben in einem dafür reservierten Speicherbereich, dem Journal, aufzeichnet. Damit ist es zu jedem Zeitpunkt möglich, einen konsistenten Zustand der Daten zu rekonstruieren, auch wenn ein Schreibvorgang an beliebiger Stelle abgebrochen wurde. Diese Eigenschaft ist im Fall von Systemabstürzen oder Stromausfällen von Vorteil. So kann die bei herkömmlichen Dateisystemen nach solchen Vorfällen oft automatisch gestartete Überprüfung des ganzen Dateisystems mit oft erfolglosen Reparaturversuchen entfallen. Speziell bei großen Festplatten mit Partitionsgrößen über 100 Gigabyte ergibt sich hieraus auch 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.

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 aufwändig 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.

Funktion des Journalings

Das Journaling-Konzept wirkt dieser Problematik entgegen. Angenommen, 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, wie viele Ä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.

Auswahl von Journaling-Dateisystemen

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.

Weblinks


Kategorien: Journaling-Dateisystem

Quelle: Wikipedia - http://de.wikipedia.org/wiki/Journaling-Dateisystem (Vollständige Liste der Autoren des Textes [Versionsgeschichte])    Lizenz: CC-by-sa-3.0

Änderungen: Alle Bilder mit den meisten Bildunterschriften wurden entfernt. Ebenso alle zu nicht-existierenden Artikeln/Kategorien gehenden internen Wikipedia-Links (Bsp. Portal-Links, Redlinks, Bearbeiten-Links). Entfernung von Navigationsframes, Geo & Normdaten, Mediadateien, gesprochene Versionen, z.T. ID&Class-Namen, Style von Div-Containern, Metadaten, Vorlagen, wie lesenwerte Artikel. Ansonsten sind keine Inhaltsänderungen vorgenommen worden. Weiterhin kann es durch die maschinelle Bearbeitung des Inhalts zu Fehlern gerade in der Darstellung kommen. Darum würden wir jeden Besucher unserer Seite darum bitten uns diese Fehler über den Support mittels einer Nachricht mit Link zu melden. Vielen Dank!

Stand der Informationen: August 201& - Wichtiger Hinweis: Da die Inhalte maschinell von Wikipedia übernommen wurden, ist eine manuelle Überprüfung nicht möglich. Somit garantiert LinkFang.de nicht die Richtigkeit und Aktualität der übernommenen Inhalte. Sollten die Informationen mittlerweile fehlerhaft sein, bitten wir Sie darum uns per Support oder E-Mail zu kontaktieren. Wir werden uns dann innerhalb von spätestens 10 Tagen um Ihr Anliegen kümmern. Auch ohne Anliegen erfolgt mindestens alle drei Monate ein Update der gesamten Inhalte.