5.2 Recovery from System Failures
Recovery from System Failures
System failures (also called soft crashes) are those failures like power outage which affect all transactions in progress, but do not physically damage the database.
During a system failure, the contents of the main memory are lost. Thus the contents of the database buffers which contain the updates of transactions are lost. (Note: Transactions do not directly write on to the database. The updates are written to database buffers and, at regular intervals, transferred to the database.) At restart, the system has to ensure that the ACID properties of transactions are maintained and the database remains in a consistent state. To attain this, the strategy to be followed for recovery at restart is as follows:
- Transactions which were in progress at the time of failure have to be undone at the time of restart. This is needed because the precise state of such a transaction which was active at the time of failure is no longer known and hence cannot be successfully completed.
- Transactions which had completed prior to the crash but could not get all their updates transferred from the database buffers to the physical database have to redone at the time of restart.
This recovery procedure is carried out with the help of
• An online logfile or journal – The logfile maintains the before- and after-images of the tuples updated during a transaction. This helps in carrying out the UNDO and REDO operations as required. Typical entries made in the logfile are :
- Start of Transaction Marker
- Transaction Identifier
- Record Identifier
- Operations Performed
- Previous Values of Modified Data (Before-image or Undo Log)
- Updated Values of Modified Records (After-image or Redo Log)
- Commit / Rollback Transaction Marker
• Taking a checkpoint at specific intervals – This involves the following two operations:
a) physically writing the contents of the database buffers out to the physical database. Thus during a checkpoint the updates of all transactions, including both active and committed transactions, will be written to the physical database.
b)physically writing a special checkpoint record to the physical log. The checkpoint record has a list of all active transactions at the time of taking the checkpoint.
0 comments:
Post a Comment