Package de.bsvrz.ars.ars.mgmt.tasks
Klasse MirrorTask
java.lang.Object
de.bsvrz.ars.ars.mgmt.tasks.Task
de.bsvrz.ars.ars.mgmt.tasks.CronTask
de.bsvrz.ars.ars.mgmt.tasks.MirrorTask
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:
- Schreibe die Indexe, leere den Cache und unterdrücke weitere Schreibvorgänge
- 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.
- 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.
- 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
-
Verschachtelte Klassen - Übersicht
Von Klasse geerbte verschachtelte Klassen/Schnittstellen de.bsvrz.ars.ars.mgmt.tasks.CronTask
CronTask.CronTaskDefinition
-
Feldübersicht
Von Klasse geerbte Felder de.bsvrz.ars.ars.mgmt.tasks.Task
_shouldTerminate
-
Konstruktorübersicht
KonstruktorenKonstruktorBeschreibungMirrorTask
(ArchiveManager archiveMgr, LongTermTaskStatePublisher longTermTaskStatePublisher) Konstruktor -
Methodenübersicht
Modifizierer und TypMethodeBeschreibungvoid
Führt einen Backup-lauf durchvoid
Terminiert den Task, indem dafür gesorgt wird, dasTask.shouldTerminate()
true zurückliefert.Von Klasse geerbte Methoden de.bsvrz.ars.ars.mgmt.tasks.CronTask
getName, isAlive, isTerminated, join, setCronTaskDefinitions, setName, start
Von Klasse geerbte Methoden de.bsvrz.ars.ars.mgmt.tasks.Task
getArchMgr, getDidTree, getPersistenceManager, shouldTerminate, suspendTaskIfNecessary
-
Konstruktordetails
-
MirrorTask
Konstruktor- Parameter:
archiveMgr
- ArchivmanagerlongTermTaskStatePublisher
- Publisher
-
-
Methodendetails
-
terminateTask
public void terminateTask()Beschreibung aus Klasse kopiert:Task
Terminiert den Task, indem dafür gesorgt wird, dasTask.shouldTerminate()
true zurückliefert. Der Task sollte diese Funktion regelmäßig aufrufen um dann bei Rückgabe vontrue
den Task zeitnah zu beenden.- Setzt außer Kraft:
terminateTask
in KlasseCronTask
-
doMirror
Führt einen Backup-lauf durch- Parameter:
targetBaseDir
- ZielverzeichniscommandLine
- Kommando, das nach dem erfolgreichen Ausführen ausgeführt wird.
-