Academic
Publications
Design Patterns for Log-Based Rollback Recovery

Design Patterns for Log-Based Rollback Recovery,Titos Saridakis

Design Patterns for Log-Based Rollback Recovery   (Citations: 1)
BibTex | RIS | RefWorks Download
Abstract Log-based rollback recovery builds on the ideas of checkpoint-based rollback recovery and improves the characteristics of the recovery process. The basic idea capture by the log-based rollback recovery techniques is an extension of the checkpoint idea. Only, instead of relying solely on checkpoints for recovering from the occurrence of an error, the system logs information about the non-deterministic events (e.g. the reception of a message) that happen between successive checkpoints. After an error occurs, the system uses checkpoints to recover a recent error-free state and replays the logged events to move its execution to a point as close as possible to the occurrence of the error. This paper presents four design patterns that capture the most widely used methods for log-based rollback recovery. First, the Logger pattern captures the general log-based rollback recovery idea. Then, the other three patterns (Optimistic Logging, Pessimistic Logging ,a ndCausal Logging )d escribes specific solutions about when, where and how to keep logs about the nondeterministic events that have driven the execution of the system. The Optimistic Logging pattern describes the method that keeps the logs of the communication events in the volatile memory,of system constituents without blocking their execution until the logs are safely moved to stables storage. The Pessimistic Logging pattern describes the opposite logging method: the log of every communication must be first stored in stable storage before the system constituent is able to continue its execution. Finally, the Causal Logging pattern captures a hybrid method between the other two mentioned before, in an attempt to combine their benefits in terms of costs incurring to the system executions with and without errors. Note to the reader: The first two sections (Introduction and Background) contain a quick overview of fault tolerance terminology and system recovery concepts for the reader who might be not very familiar with those. If the reader feels comfortable with this terminology and concepts then he/she may skip these two sections and focus on the three patterns that follow and which are the material that the author would like to be reviewed in the writers workshop.
Cumulative Annual
    • ...+ Compared to fault tolerance design patterns [16, 17, 19], the State Decrement pattern has lower costs in terms of system complexity and time and space overhear during system execution, while it ensures the continuation of a gracefully degraded system execution in the presence of errors...
    • ...+ The use of the State Decrement pattern does not preclude the use of fault tolerance patterns [16, 17, 19] in the system design...
    • ...+T heState Decrement pattern does not introduce any time overhead to error-free system executions, unlike some fault tolerance patterns for checkpoint-based rollback recovery [17] and log-based rollback recovery [19]...

    Titos Saridakis. Design Patterns for Graceful Degradation

Sort by: