Slideshow:
|
|
|
|
|
/* ================================================== Step 1: identify the commited transactions ================================================== */ Scan the redo log backwards until the <START CKPT(T1, T2, ..., Tk) record: { identify the committed identify the uncommitted/aborted transactions } /* ================================================== Step 2: redo the commited transactions ================================================== */ Scan the redo log backwards until we found all <START T1>, <START T2>, ..., <START Tk> records Starting from this point, scan the redo log forewards { For ( each < T, A, v > ) { if ( T is commited ) { Update A with the (after) value v; // Redo the action !!! } } } /* ========================================================= Step 3: mark the uncommited tranasactions as failed.... ========================================================= */ For ( each T that is uncommited ) do { Write <ABORT T> to log; } Flush-Log |
|
|
|
|
|
|
/* ==================================================
Step 1: identify the commited transactions
================================================== */
Scan the redo log backwards until first <START CKPT(T1, T2, ..., Tk) record:
{
identify the committed
identify the uncommitted/aborted transactions
}
/* ==================================================
Step 2: redo the commited transactions
================================================== */
Scan the redo log backwards
until we found all <START T1>, <START T2>, ..., <START Tk> records
Starting from this point, scan the redo log forewards
{
For ( each < T, A, v > where T is commited ) do
{
Update A with the (after) value v; // Redo the action !!!
}
}
/* =========================================================
Step 3: mark the uncommited tranasactions as failed....
========================================================= */
For ( each T that is uncommited ) do
{
Write <ABORT T> to log;
}
Flush-Log
|