Advanced Database Systems: Chapter 4: Transaction Management
Advanced Database Systems: Chapter 4: Transaction Management
Advanced Database Systems: Chapter 4: Transaction Management
1
Chapter Outline:
▪ Transaction and System Concepts
▪ Properties of Transaction
▪ Schedules and Recoverability
▪ Serializability of Schedules
▪ Database Concurrency Control
▪ Locking Techniques for Concurrency Control
• Locking
• 2PL
• Timestamping
2
1. Introduction
A Transaction:
– Logical unit of database processing that includes one or more access operations (read
-retrieval, write - insert or update, delete).
• Examples include ATM transactions, credit card approvals, flight reservations, hotel check-
in, phone calls, supermarket scanning, academic registration and billing.
• Transaction boundaries:
– Any single transaction in an application program is bounded with Begin and End
statements.
• An application program may contain several transactions separated by the Begin and
End transaction boundaries.
3
SIMPLE MODEL OF A DATABASE :
• A database is a collection of named data items
• Granularity of data - a field, a record , or a whole
disk block that measure the size of the data item
• Basic operations that a transaction can perform
are read and write
– read_item(X): Reads a database item named X into
a program variable. To simplify our notation, we
assume that the program variable is also named X.
– write_item(X): Writes the value of program variable
X into the database item named X.
4
Exercise
X=1000; y=550;
T1
Read(y)
Y=y+x
Write(y) y= ?
Y=y-50
Write(y) y=?
• Basic unit of data transfer from the disk to the computer main
memory is one block.
• read_item(X) command includes the following steps:
– Find the address of the disk block that contains item X.
– Copy that disk block into a buffer in main memory (if that
disk block is not already in some main memory buffer).
– Copy item X from the buffer to the program variable
named X.
• write_item(X) command includes the following steps:
– Find the address of the disk block that contains item X.
– Copy that disk block into a buffer in main memory (if that
disk block is not already in some main memory buffer).
– Copy item X from the program variable named X into its
correct location in the buffer.
– Store the updated block from the buffer back to disk
(either immediately or at some later point in time).
8
• The DBMS maintains a number of buffers in the main
memory that holds database disk blocks which contains the
database items being processed.
– When this buffers are occupied and
– if there is a need for additional database block to be
copied to the main memory ;
• some buffer management policy is used to choose for
replacement but if the chosen buffer has been modified , it
must be written back to disk before it is used.
• Two sample transactions:
– (a) Transaction T1
– (b) Transaction T2
9
2. Transaction and System Concepts
• A transaction is an atomic unit of work that is either completed in
its entirety or not done at all.
– For recovery purposes, the system needs to keep track of when
the transaction starts, terminates, and commits or aborts.
• Transaction states:
– Active state -indicates the beginning of a transaction execution
– Partially committed state shows the end of read/write operation
but this will not ensure permanent modification on the data base
– Committed state -ensures that all the changes done on a record
by a transition were done persistently
– Failed state happens when a transaction is aborted during its
active state or if one of the rechecking is fails
– Terminated State -corresponds to the transaction leaving the
system
10
State transition diagram illustrating the states for
transaction execution
11
To summarize, the above state transition diagram illustrates how a transaction moves through its
execution states. A transaction goes into an active state immediately after it starts execution, where it
can execute its READ and WRITE operations. When the transaction ends, it moves to the partially
committed state. At this point, some recovery protocols need to ensure that a system failure will not
result in an inability to record the changes of the transaction permanently (usually by recording
changes in the system log,
Once this check is successful, the transaction is said to have reached its commit point and enters the
committed state. When a transaction is committed, it has concluded its execution successfully and all
its changes must be recorded permanently in the database, even if a system failure occurs.
We Can have one of two outcomes:
Success - transaction commits and database reach a new consistent state. Committed
transaction cannot be aborted. COMMIT signals the successful end of a transaction. Any
changes made by the transaction should be saved. These changes are now visible to other
transactions
Failure - transaction aborts, and database must be restored to consistent state before it
started Such a transaction is rolled back or undone. Aborted transaction that is rolled back
can be restarted (redone) later. ROLLBACK signals the unsuccessful end of a
transaction. Any changes made by the transaction should be undone. It is now as if the
transaction never existed.
– T in the following discussion refers to a unique transaction-id that is
generated automatically by the system and is used to identify each
transaction:
– Types of log record:
• [start_transaction,T]: Records that transaction T has started
execution.
• [write_item,T,X,old_value,new_value]: Records that transaction T
has changed the value of database item X from old_value to
new_value.
• [read_item,T,X]: Records that transaction T has read the value of
database item X.
• [commit,T]: Records that transaction T has completed successfully,
and affirms that its effect can be committed (recorded permanently)
to the database.
• [abort,T]: Records that transaction T has been aborted.
14
3. Desirable Properties of Transactions
To ensure data integrity , DBMS should maintain the following ACID
properties:
• Atomicity: A transaction is an atomic unit of processing; it is either
performed in its entirety or not performed at all.
• Consistency preservation: A correct execution of the transaction must take
the database from one consistent state to another.
• Isolation: A transaction should not make its updates visible to other
transactions until it is committed; this property, when enforced strictly, solves
the temporary update problem and makes cascading rollbacks of
transactions unnecessary
• Durability or permanency: Once a transaction changes the database and
the changes are committed, these changes must never be lost because of
subsequent failure.
15
Example:
• Suppose that Ti is a transaction that transfer 200 birr from account CA2090( which has
5,000 Birr) to SB2359(which has 3,500 birr) as follows
• Read(CA2090)
• CA2090= CA2090-200
• Write(CA2090)
• Read(SB2359)
• SB2359= SB2359+200
• Write(SB2359)
• Atomicity- either all or none of the above operation will be done – this is materialized by
transaction management component of DBMS
• Consistency-the sum of CA2090 and SB2359 be unchanged by the execution of Ti i.e
8500- this is the responsibility of application programmer who codes the transaction
• Isolation- when several transaction are being processed concurrently on a data item they
may create many inconsistent problems. So handling such case is the responsibility of
Concurrency control component of the DBMS
• Durability - once Ti writes its update this will remain there when the database restarted
from failure . This is the responsibility of recovery management components of the
DBMS
16
Modes of Concurrency
• Interleaved processing: concurrent execution of processes is interleaved on a single
CPU
• Parallel processing: processes are concurrently executed on multiple CPUs. Multiple
transactions are allowed to run concurrently in the system. Concurrency control
schemes – mechanisms to achieve isolation, i.e., to control the interaction among the
concurrent transactions in order to prevent them from destroying the consistency of the
database.
Advantages of parallel processing are:
o increased processor and disk utilization, leading to better transaction throughput: one
transaction can be using the CPU while another is reading from or writing to the disk
o reduced average response time for transactions: short transactions need not wait behind
long ones.
17
Why Concurrency Control is needed: Three cases
18
▪ E.g. Account with balance A=100.
▪ T1 reads the account A
▪ T1 withdraws 10 from A
▪ T1 makes the update in the Database
▪ T2 reads the account A
▪ T2 adds 100 on A
▪ T2 makes the update in the Database
▪ In the above case, if done one after the other (serially) then we have no problem.
❖ If the execution is T1 followed by T2 then A=190
❖ If the execution is T2 followed by T1 then A=190
▪ But if they start at the same time in the following sequence:
T1 T2
❑ T1 reads the account A=100
Read_item(A)
❑ T1 withdraws 10 making the balance A=90 A=A-10
❑ T2 reads the account A=100 Read_item(A)
A=A+100
❑ T2 adds 100 making A=200
Write_item(A)
❑ T1 makes the update in the Database A=90 Write_item(A)
❑ T2 makes the update in the Database A=200
▪ After the successful completion of the operation the final value of A will be 200 which override
the update made by the first transaction that changed the value from 100 to 90.
19
B) The Temporary Update (or Dirty Read) Problem
– This occurs when one transaction updates a database
item and then the transaction fails for some reason .
– The updated item is accessed by another transaction
before it is changed back to its original value. Based on
the above scenario:
T1 T2
Read_item(A) Fig 2: Temporal update problem
A=A+100
Write_item(A)
Read_item(A)
A=A-10 Transaction T2 fails and must change the
Write_item(A) values of A back to its old value;
Abort Meanwhile T1 has read the temporary
incorrect value of A
Commit
T2 increases A making it 200 but then aborts the transaction before it is committed.
T1 gets 200, subtracts 10 and make it 190. But the actual balance should be 90
20
C) The Incorrect Summary Problem
– If one transaction is calculating an aggregate summary function on
a number of records while other transactions are updating some of
these records, the aggregate function may calculate some values
before they are updated and others after they are updated.
Example: T1 would like to add the values of A=10, B=20 and C=30. after the values
are read by T1 and before its completion, T2 updates the value of B to be 50. at the
end of the execution of the two transactions T1 will come up with the sum of 60
while it should be 90 since B is updated to 50
T1 T2
Sum= 0;
Read_item(A)
Sum=Sum+A
Read_item(B)
Sum=Sum+B
Read_item(B)
B=50
Read_item(C)
Sum=Sum+C
21
Schedule
Schedule: a sequence of instructions that specify the chronological order in which
instructions of concurrent transactions are executed.
A schedule for a set of transactions must consist of all instructions of those
transactions. Schedule must preserve the order in which the instructions appear in
each individual transaction.
• A transaction that successfully completes its execution will have a commit
instruction as the last statement (will be omitted if it is obvious)
• A transaction that fails to successfully complete its execution will have an abort
instruction as the last statement (will be omitted if it is obvious)
Example Schedules
Let T1 transfer $50 from A to B, and T2 transfer 10% of the balance from A to B.
schedule S1 is a serial schedule in which T1 is followed by T2.
schedule S2 is a serial schedule in which T2 is followed by T1.
Schedule S3 is not serial, but it is equivalent to Schedule S1 and S2.
The following concurrent schedule does not preserve the value of (A + B) and violates the consistency requirement
The Transaction Log
• The transaction log records the details of all transactions - Any changes the
transaction makes to the database. The log is stored on disk, not in
memory(RAM)- If the system crashes it is preserved.
• Write ahead log rule - The entry in the log must be made before COMMIT
processing can complete.
Serializability of Schedule
Basic Assumption: Each transaction preserves database consistency
Thus, serial execution of a set of transactions preserves database
consistency.
We ignore operations other than read and write and we assume that
transactions may perform arbitrary/random computations on data in
local.
Serializability in DBMS
• Serializability is the concept in a transaction that helps to identify which non-
serial schedule is correct and will maintain the database consistency.
No concurrency is allowed.
Concurrency is allowed.
Thus, all the transactions
Thus, multiple transactions can
necessarily execute serially one
execute concurrently.
after the other.
Schedule C gives an erroneous result because of the lost update problem discussed.
transaction T2 reads the value of X before it is changed by transaction T1, so only the
effect of T2 on X is reflected in the database. The effect of T1 on X is lost, overwritten
by T2, leading to the incorrect result for item X. However, some nonserial schedules
give the correct expected result, such as schedule D. We would like to determine
which of the nonserial schedules always give a correct result and which may give
erroneous results. The concept used to characterize schedules in this manner is that of
serializability of a schedule.
Database Concurrency Control
33
1. Purpose of Concurrency Control
– To enforce Isolation (through mutual exclusion) among conflicting
transactions.
– To preserve database consistency through consistency preserving execution
of transactions.
– To resolve read-write and write-write conflicts.
• A typical scheduler does its work by maintaining locks on certain pieces of the
database.
• These locks prevent two transactions from accessing the same piece of data at
the same time.
Example:
– In concurrent execution environment, if T1 conflicts with T2 over a data
item A, then the existing concurrency control decides if T1 or T2 should get
the A and if the other transaction is rolled-back or waits.
34
Example:
A = 500
Account B = 500
Balances
C = 500
Property: A + B + C = 1500
t = t - 100 s = s - 100
t = t + 100 s = s + 100
36
Transaction T1 Transaction T2 A B C
Read (C, s)
s = s + 100
Write (C, s) 400 600 600
Schedule 37
400 + 600 + 600 = 1600
Transaction T1 Transaction T2 A B C
Read (C, s)
s = s + 100
Alternative Write (C, s) 300 600 600
Schedule
300 + 600 + 600 = 1500 38
So What ?
2. Concurrency Control Techniques
• Basic concurrency control techniques:
– Locking,
– Timestamping
• The two are conservative approaches: delay transactions in
case they conflict with other transactions.
• Optimistic methods assume conflict is rare and only check
for conflicts at commit.
39
2.1. Locking
• Lock is a variable associated with a data item that describes the status of the data
item with respect to the possible operations that can be applied to it.
• Generally, a transaction must claim a shared (read) or exclusive (write) lock on a
data item before read or write.
• Lock prevents another transaction from modifying item or even reading it, in the
case of a write lock.
– Locking is an operation which secures
• (a) permission to Read
• (b) permission to Write a data item for a transaction.
• Example:
– Lock (X). Data item X is locked in behalf of the requesting transaction.
– Unlocking is an operation which removes these permissions from the data item.
• Example:
– Unlock (X): Data item X is made available to all other transactions.
– Lock and Unlock are Atomic operations.
40
▪ Two locks modes:
• (a) shared (read) (b) exclusive (write).
• Shared mode: shared lock (X)
– More than one transaction can apply share lock on X for
reading its value but no write lock can be applied on X by any
other transaction.
• Exclusive mode: Write lock (X)
– Only one write lock on X can exist at any time and no shared
lock can be applied by any other transaction on X.
▪ Conflict matrix
Read Write
Read
Y N
Write
N N
41
▪ Lock Manager:
• Managing locks on data items.
▪ Lock table:
• Lock manager uses it to store the identify of transaction locking a
data item, the data item, lock mode and pointer to the next data
item locked. One simple way to implement a lock table is through
linked list.
43
• Lock conversion
– Lock upgrade: existing read lock to write lock
if T1 has a read-lock (X) and T2 has no read-lock (X) (T1 T2)
then
convert read-lock (X) to write-lock (X)
else
force T1 to wait until T2 unlocks X
– Lock downgrade: existing write lock to read lock
T1 has a write-lock (X) (*no transaction can have any lock on X*) convert
write-lock (X) to read-lock (X)
• Using such locks in the transaction do not guarantee Serializability of
schedule on its own
44
1.1 Simple Locking
T1 T2
read_lock (Y);
read_item (Y);
unlock Result
(Y);
read_lock (X); X=50; Y=50
read_item (X); Non-serializable because it
unlock (X); violated two-phase policy.
write_lock (Y);
read_item (Y);
Y:=X+Y;
write_item (Y);
Time unlock (Y);
write_lock (X); • Problem is that transactions release locks too soon, resulting in
read_item (X); loss of total isolation and atomicity.
X:=X+Y;
write_item (X); • To guarantee Serializability, we need an additional protocol
unlock (X); concerning the positioning of lock and unlock operations in every
transaction.
45
2.2 Two-Phase Locking Techniques: The algorithm
▪ Transaction follows 2PL protocol, if all locking operations precede first unlock operation in the
transaction.
• Every transaction can be divided into Two Phases: Locking (Growing) & Unlocking (Shrinking)
– Locking (Growing) Phase:
• A transaction applies locks (read or write) on desired data items one at a time.
• acquires all locks but cannot release any locks.
– Unlocking (Shrinking) Phase:
• A transaction unlocks its locked data items one at a time.
• Releases locks but cannot acquire any new locks.
• Requirement:
– For a transaction these two phases must be mutually exclusively/complete, that is, during
locking phase unlocking phase must not start and during unlocking phase locking phase must
not begin.
# locks
held by
Ti
47
T1 T2
read_lock (Y);
read_item (Y);
unlock Result
(Y);
read_lock (X); X=50; Y=50
read_item (X); Non-serializable because it
unlock (X); violated two-phase policy.
write_lock (Y);
read_item (Y);
Y:=X+Y;
write_item (Y);
Time unlock (Y);
write_lock (X); •Problem is that transactions release locks too soon, resulting in
read_item (X); loss of total isolation and atomicity.
X:=X+Y;
write_item (X); •To guarantee Serializability, we need an additional protocol
unlock (X); concerning the positioning of lock and unlock operations in
every transaction.
48
T’1 T’2
read_lock (Y); read_lock (X);
read_item (Y); read_item (X); T’1 and T’2 follow two-phase
write_lock (X); Write_lock (Y); policy but they are subject to
deadlock, which must be dealt
unlock (Y); unlock (X); . with
read_item (X); read_item (Y);
X:=X+Y; Y:=X+Y;
write_item (X); write_item (Y);
unlock (X); unlock (Y);
50
Dealing with Deadlock and Starvation
A. Deadlock
– It is a state that may result when two or more transaction are each waiting for
locks held by the other to be released.
– Example :
T1 T2
read_lock (Y);
read_item (Y);
read_lock (X);
read_item (X);
write_lock (X);
write_lock (Y);
– T1 is in the waiting queue for X which is locked by T2
– T2 is on the waiting queue for Y which is locked by T1
– No transaction can continue until the other transaction completes
– T1 and T2 did follow two-phase policy but they are deadlock
• So the DBMS must either prevent or detect and resolve such deadlock situations
51
• There are possible solutions : Deadlock prevention, deadlock detection and avoidance, and lock
timeouts
i. Deadlock prevention protocol: two possibilities
▪ The conservative two-phase locking
− A transaction locks all data items it refers to before it begins execution.
− This way of locking prevents deadlock since a transaction never waits for a data item.
− Limitation : It restrictions concurrency
▪ Transaction Timestamp( TS(T) )
▪ We can prevent deadlocks by giving each transaction a priority and ensuring that lower
priority transactions are not allowed to wait for higher priority transactions (or vice versa ).
▪ One way to assign priorities is to give each transaction a timestamp when it starts up.
▪ it is a unique identifier given to each transaction based on time in which it is started. i.e. if T1
starts before T2 , TS(T1)<TS(T2): FCFS issue
▪ The lower the timestamp, the higher the transaction's priority, that is, the oldest transaction
has the highest priority.
▪ If a transaction T1 requests a lock and transaction T2 holds a conflicting lock, the lock
manager can use one of the following two policies: Wait-die & Would-wait
Reading assignment: Wait-die & Would-wait
52
• Wait-die
– If T1 has higher priority, it is allowed to wait; otherwise it is aborted.
– An older transaction is allowed to wait on a younger transaction.
– A younger transaction requesting an item held by an older transaction is
aborted
– If TS(T1) < TS(T2), then (T1 older than T2) T1 is allowed to wait.
– Otherwise (T1 younger than T2)Abort T1 (T1 dies) and restart it later with
the same timestamp
wait
wait
T1(ts =25)
wait
T2 (ts =20)
wait wait
T3 (ts =10) 54 ??
▪ Remark:
− Both methods ended by aborting the younger of the two transaction that
may be involved in the deadlock
− Limitation:
− Both techniques may cause some transaction to be aborted and
restarted needlessly
ii. Deadlock Detection and resolution
– In this approach, deadlocks are allowed to happen
– The scheduler maintains a wait-for-graph for detecting cycle.
– When a chain like: Ti waits for Tj waits for Tk waits for Ti or Tj occurs,
then this creates a cycle.
– When the system is in the state of deadlock, some of the transaction
should be aborted by selected (victim) and rolled-back.
– This can be done by aborting those transaction: that have made the least
work, the one with the lowest locks, and that have the least # of abortion
and so on
– Example:
55
iii. Timeouts
– It uses the period of time that several transaction have been waiting to lock items
– It has lower overhead cost and it is simple
– If the transaction wait for a longer time than the predefined time out period, the
system assume that may be deadlocked and aborted it.
B. Starvation
– Starvation occurs when a particular transaction consistently waits or restarted and
never gets a chance to proceed further while other transaction continue normally
– This may occur, if the waiting method for item locking:
• Gave priority for some transaction over others
• Problem in Victim selection algorithm- it is possible that the same transaction may
consistently be selected as victim and rolled-back .example In
Solution
• FIFO
• Allow for transaction that wait for a longer time
• Give higher priority for transaction that have been aborted for many time
56
4. Schedules and Recoverability
❑ Why recovery is needed:
• Whenever a transaction is submitted to the DBMS for execution, the system is
responsible for making sure that either all operations in the transaction to be
completed successfully or the transaction has no effect on the database or any other
transaction.
• The DBMS may permit some operations of a transaction T to be applied to the
database but a transaction may fails after executing some of its operations.
• What causes a Transaction to fail
1. A computer failure (system crash):
A hardware or software error occurs in the computer system during transaction
execution. If the hardware crashes, the contents of the computer’s internal
memory may be lost.
2. A transaction or system error:
Some operation in the transaction may cause it to fail, such as integer
overflow or division by zero. Transaction failure may also occur because of
erroneous parameter values or because of a logical programming error. In
addition, the user may interrupt the transaction during its execution.
57
3. Exception conditions detected by the transaction:
– Certain conditions forces cancellation of the transaction.
For example, data for the transaction may not be found. such as insufficient
account balance in a banking database, may cause a transaction, such as a
fund withdrawal from that account, to be canceled.
4. Concurrency control enforcement:
The concurrency control method may decide to abort the transaction, to
be restarted later, because it violates Serializability or because several
transactions are in a state of deadlock.
5. Disk failure:
Some disk blocks may lose their data because of a read or write malfunction
or because of a disk read/write head crash. This may happen during a read
or a write operation of the transaction.
6. Physical problems and catastrophes:
This refers to an endless list of problems that includes power or air-
conditioning failure, fire, theft, overwriting disks or tapes by mistake
58
Transactions should be durable, but we cannot prevent all sorts of failures:
• Natural disasters
Prevention(precaution) is better than cure/treatment(post action)
• Reliable OS
• Security
• UPS and surge protectors
Database Recovery Techniques
60
▪ Transaction Manager : Accepts transaction commands from an application, which
tell the transaction manager when transactions begin and end, as well as information
about the expectations of the application.
The transaction processor performs the following tasks:
61
1. Recovery Concept
i. Purpose of Database Recovery
– To bring the database into the last consistent state, which existed prior to the
failure.
– To preserve transaction properties (Atomicity & Durability).
• The recovery manager of a DBMS is responsible to ensure
– atomicity by undoing the action of transaction that do not commit
– Durability by making sure that all actions of committed transaction
survive system crash.
i. Types of Failure
– The database may become unavailable for use due to :
• Transaction failure: Transactions may fail because of
incorrect input, deadlock.
• System failure: System may fail because of addressing
error, application error, operating system fault, RAM
failure, etc.
• Media failure: Disk head crash, power disruption, etc. 62
▪ To recover from system failure, the system keeps information about the
change in the system log.
▪ Strategy for recovery may be summarized as :
▪ Recovery from catastrophic
▪ If there is extensive damage to the wide portion of the database
▪ This method restore a past copy of the database from the backup
storage and reconstructs operation of a committed transaction from
the back up log up to the time of failure.
▪ Recovery from non-catastrophic failure
▪ When the database is not physically damaged but has become in
consistent.
▪ The strategy uses undoing and redoing some operations in order to
restore to a consistent state.
63
▪ For instance,
– If failure occurs between commit and database buffers being flushed
to secondary storage then, to ensure durability, recovery manager has to
redo (roll forward) transaction’s updates.
– If transaction had not committed at failure time, recovery manager has
to undo (rollback) any effects of that transaction for atomicity.
Fig 2 :
status of
transactions at
the time of
system fails
66
– Immediate Update:
▪ As soon as a data item is modified in cache, the disk copy is
updated.
▪ These update are first recorded on the log and on the disk by force
writing, before the database is updated
▪ If a transaction fails after recording some change to the database
but before reaching its commit point , this will be rolled back
– Shadow update:
▪ The modified version of a data item does not overwrite its disk
copy but is written at a separate disk location.
▪ Multiple version of the same data item can be maintained
▪ Thus the old value ( before image BFIM) and the new value
(AFIM) are kept in the disk
▪ No need of Log for recovery
– In-place update: The disk version of the data item is overwritten by
the cache version.
67
I. Data Caching
▪ Data items to be modified are first stored into database
cache by the Cache Manager (CM) and after modification
they are flushed (written) to the disk
▪ When DBMS request for read /write operation on some item
▪ It check the requested data item is in the cache or not
▪ If it is not, the appropriate disk block are copied to the
cache
▪ If the cache is already full, some buffer replacement
policy can be used . Like
▪ Least recent used (LRU)
▪ FIFO
▪ While replacing buffers , first of all the updated value on
that buffer should be saved on the appropriate block in
the data base
68
I. Write-Ahead Logging
▪ When in-place update (immediate or deferred) is used then log is
necessary for recovery
▪ This log must be available to recovery manager
– This is achieved by Write-Ahead Logging (WAL) protocol. WAL
states that
69
❑ Standard Recovery Terminology
▪ Possible ways for flushing database cache to database disk:
i. No-Steal: Cache cannot be flushed before transaction commit.
ii. Steal: Cache can be flushed before transaction commits.
iii. Force: if all Cache updates are immediately flushed (forced) to disk
when a transaction commits------> force writing
iv. No-Force: if Cached are flushed to a disk when the need arise after a
committed transaction
▪ These give rise to four different ways for handling recovery:
• Steal/No-Force (Undo/Redo)
• Steal/Force (Undo/No-redo)
• No-Steal/No-Force (No-undo/Redo)
• No-Steal/Force (No-undo/No-redo)
70
2. Recovery Scheme
i. Deferred Update (No Undo/Redo)
– The data update goes as follows:
▪ A set of transactions records their updates in the log.
▪ At commit point under WAL scheme these updates are saved on
database disk.
▪ No undo is required because no AFIM is flushed to the disk before a
transaction commits.
▪ After reboot from a failure the log is used to redo all the transactions
affected by this failure.
– Limitation: out of buffer space may be happened because transaction
changes must be held in the cache buffer until the commit point
– Type of deferred updated recovery environment
▪ Single User and Multiple user environment
a) Deferred Update in a single-user system
▪ There is no concurrent data sharing in a single user system.
▪ The data update goes as follows:
▪ A set of transactions records their updates in the log.
▪ At commit point under WAL scheme these updates are saved on
71
database disk.
72
a) Deferred Update with concurrent users
▪ This environment requires some concurrency control
mechanism to guarantee isolation property of transactions.
▪ In a system recovery, transactions which were recorded in
the log after the last checkpoint were redone.
▪ The recovery manager may scan some of the transactions
recorded before the checkpoint to get the AFIMs.
▪T4 and T5 are ignored because they didn’t reach their commit points
▪T1, T2 and T3 are redone because their commit point is after the last
checkpoint
73
▪ Two tables are required for implementing this protocol:
▪ Active table: All active transactions are entered in this
table.
▪ Commit table: Transactions to be committed are entered in
this table.
▪ During recovery, all transactions of the commit table are
redone and all transactions of active tables are ignored since
none of their AFIMs reached the database.
▪ It is possible that a commit table transaction may be redone
twice but this does not create any inconsistency because of a
redone is “idempotent”,
▪ that is, one redone for an AFIM is equivalent to multiple
redone for the same AFIM.
74
ii. Recovery Techniques Based on Immediate Update
▪ Undo/No-redo Algorithm
– In this algorithm AFIMs of a transaction are flushed to the
database disk under WAL before it commits.
– For this reason the recovery manager undoes all transactions
during recovery.
– No transaction is redone.
– It is possible that a transaction might have completed execution
and ready to commit but this transaction is also undone.
75
iii. Shadow Paging Recovery
▪ Maintain two page tables during life of a transaction: current page and
shadow page table.
▪ When transaction starts, two pages are the same.
▪ Shadow page table is never changed thereafter and is used to restore
database in event of failure.
▪ During transaction, current page table records all updates to database.
▪ When transaction completes, current page table becomes shadow page
table.
X Y
X' Y'
Database
78