Class MirrorTask


public final class MirrorTask extends CronTask
Task-Implementierung vom datenkonsistenten Backup.

Grundgedanke des datenkonsitenten Backups ist, dass es ausreichend ist, alle Containerverzeichnisse (bzw. Datenidentifikationen) einzeln in einem konsistenten Zustand zu sichern.

Zur Umsetzung dieses Konzepts würde im Archivsystem ein weiterer Hintergrundtask integriert werden, der alle Containerverzeichnisse nacheinander durchgeht und einzeln sichert. Eine parallele Bearbeitung von mehreren Verzeichnissen ist prinzipiell problemlos möglich, könnte jedoch die Systemlast erhöhen und sollte daher nicht standardmäßig aktiviert werden. Der neue Task wird regelmäßig folgende Aktionen ausführen:

  • Für jedes Containerdateienverzeichnis:
    1. Schreibe die Indexe, leere den Cache und unterdrücke weitere Schreibvorgänge
    2. Stelle sicher, dass das entsprechende Backup-Verzeichnis auf demselben Stand ist, wie das aktuelle Archivdatenverzeichnis im Persistenzverzeichnis. Das entsprechende Unterverzeichnis im Backup-Ordner wird angelegt, wenn es noch nicht existiert.
    3. Daten, die im Backup-Verzeichnis noch nicht existieren, werden kopiert, Daten, die auf einem alten bzw. abweichenden Stand sind, werden aktualisiert und Daten, die nicht mehr existieren (z. B. weil sie aus dem Archiv ausgelagert wurden), werden im Backup-Verzeichnis ebenfalls gelöscht.
    4. Hebe die Blockierung wieder auf
  • Schreibe am Ende eine _startUpInfo.property und _restartTime.property, die den Stand der gesicherten Daten angibt (die Inhalte können bei der Sicherung aggregiert werden).
  • Starte (auf Wunsch) einen vom Anwender konfigurierbaren Prozess, der die Daten aus diesem Verzeichnis noch einmal an einen anderen Ort sichert oder beispielsweise einen Schnappschuss erstellt.
  • Warte ggf. auf die Beendigung dieses Prozesses
  • Constructor Details

    • MirrorTask

      public MirrorTask(ArchiveManager archiveMgr, LongTermTaskStatePublisher longTermTaskStatePublisher)
      Konstruktor
      Parameters:
      archiveMgr - Archivmanager
      longTermTaskStatePublisher - Publisher
  • Method Details

    • terminateTask

      public void terminateTask()
      Description copied from class: Task
      Terminiert den Task, indem dafür gesorgt wird, das Task.shouldTerminate() true zurückliefert. Der Task sollte diese Funktion regelmäßig aufrufen um dann bei Rückgabe von true den Task zeitnah zu beenden.
      Overrides:
      terminateTask in class CronTask
    • doMirror

      public void doMirror(Path targetBaseDir, String[] commandLine)
      Führt einen Backup-lauf durch
      Parameters:
      targetBaseDir - Zielverzeichnis
      commandLine - Kommando, das nach dem erfolgreichen Ausführen ausgeführt wird.