Download presentation
Presentation is loading. Please wait.
Published byDarrell Domenic Rogers Modified over 9 years ago
1
CMU SCS Carnegie Mellon Univ. Dept. of Computer Science 15-415/615 - DB Applications C. Faloutsos – A. Pavlo Lecture#20: Overview of Transaction Management
2
CMU SCS Administrivia HW7 (Phase 1) is due Tues March 31 st Recitations (always in WEH 5302): –Wed April 1 st 1:30-2:20 Faloutsos/PavloCMU SCS 15-415/6152
3
CMU SCS Last Class Database Design Database Tuning Faloutsos/PavloCMU SCS 15-415/6153
4
CMU SCS Today’s Class Transactions Overview Concurrency Control Recovery Faloutsos/PavloCMU SCS 15-415/6154
5
CMU SCS Motivation We both change the same record (“Smith”); how to avoid race condition? You transfer $100 from savings→checking; power failure – what happens? Faloutsos/PavloCMU SCS 15-415/6155 Lost Updates Concurrency Control Durability Recovery
6
CMU SCS Motivation We both change the same record (“Smith”); how to avoid race condition? You transfer $100 from savings→checking; power failure – what happens? Faloutsos/PavloCMU SCS 15-415/6156 Lost Updates Concurrency Control Durability Recovery DBMSs automatically handle both issues: ‘transactions’
7
CMU SCS Concurrency Control & Recovery Valuable properties of DBMSs. Based on concept of transactions with ACID properties. Let’s talk about transactions… Faloutsos/PavloCMU SCS 15-415/6157
8
CMU SCS Transactions A transaction is the execution of a sequence of one or more operations (e.g., SQL queries) on a shared database to perform some higher-level function. It is the basic unit of change in a DBMS: –Partial transactions are not allowed! Faloutsos/PavloCMU SCS 15-415/6158
9
CMU SCS Transaction Example Move $100 from Christos’ bank account to his bookie’s account. Transaction: –Check whether Christos has $100. –Deduct $100 from his account. –Add $100 to his bookie’s account. Faloutsos/PavloCMU SCS 15-415/6159
10
CMU SCS Strawman System Execute each txn one-by-one (i.e., serial order) as they arrive at the DBMS. –One and only one txn can be running at the same time in the DBMS. Before a txn starts, copy the entire database to a new file and make all changes to that file. –If the txn completes successfully, overwrite the original file with the new one. –If the txn fails, just remove the dirty copy. Faloutsos/PavloCMU SCS 15-415/61510
11
CMU SCS Problem Statement Better approach is to allow concurrent execution of independent transactions. Q: Why do we want that? –Utilization/throughput (“hide” waiting for I/Os) –Increased response times to users. But we also would like: –Correctness –Fairness Faloutsos/PavloCMU SCS 15-415/61511
12
CMU SCS Transactions Hard to ensure correctness… –What happens if Christos only has $100 and tries to pay off two bookies at the same time? Hard to execute quickly… –What happens if Christos needs to pay off his gambling debts very quickly all at once? Faloutsos/PavloCMU SCS 15-415/61512
13
CMU SCS Problem Statement Arbitrary interleaving can lead to –Temporary inconsistency (ok, unavoidable) –Permanent inconsistency (bad!) Need formal correctness criteria. Faloutsos/PavloCMU SCS 15-415/61513
14
CMU SCS Definitions A txn may carry out many operations on the data retrieved from the database However, the DBMS is only concerned about what data is read/written from/to the database. –Changes to the “outside world” are beyond the scope of the DBMS. Faloutsos/PavloCMU SCS 15-415/61514
15
CMU SCS Formal Definitions Database: A fixed set of named data objects (A, B, C, …) Transaction: A sequence of read and write operations (R(A), W(B), …) –DBMS’s abstract view of a user program Faloutsos/PavloCMU SCS 15-415/61515
16
CMU SCS Transactions in SQL A new txn starts with the begin command. The txn stops with either commit or abort : –If commit, all changes are saved. –If abort, all changes are undone so that it’s like as if the txn never executed at all. Faloutsos/PavloCMU SCS 15-415/61516 A txn can abort itself or the DBMS can abort it.
17
CMU SCS Correctness Criteria: ACID Atomicity: All actions in the txn happen, or none happen. Consistency: If each txn is consistent and the DB starts consistent, then it ends up consistent. Isolation: Execution of one txn is isolated from that of other txns. Durability: If a txn commits, its effects persist. Faloutsos/PavloCMU SCS 15-415/61517
18
CMU SCS Correctness Criteria: ACID Atomicity: “all or nothing” Consistency: “it looks correct to me” Isolation: “as if alone” Durability: “survive failures” Faloutsos/PavloCMU SCS 15-415/61518
19
CMU SCS Transaction Demo Faloutsos/PavloCMU SCS 15-415/61519
20
CMU SCS Overview Problem definition & ‘ACID’ A tomicity C onsistency I solation D urability Faloutsos/PavloCMU SCS 15-415/61520
21
CMU SCS Atomicity of Transactions Two possible outcomes of executing a txn: –Txn might commit after completing all its actions. –or it could abort (or be aborted by the DBMS) after executing some actions. DBMS guarantees that txns are atomic. –From user’s point of view: txn always either executes all its actions, or executes no actions at all. Faloutsos/PavloCMU SCS 15-415/61521 A
22
CMU SCS Mechanisms for Ensuring Atomicity We take $100 out of Christos’ account but then there is a power failure before we transfer it to his bookie. When the database comes back on-line, what should be the correct state of Christos’ account? Faloutsos/PavloCMU SCS 15-415/61522 A
23
CMU SCS Mechanisms for Ensuring Atomicity One approach: LOGGING –DBMS logs all actions so that it can undo the actions of aborted transactions. Think of this like the black box in airplanes… Faloutsos/PavloCMU SCS 15-415/61523 A
24
CMU SCS Mechanisms for Ensuring Atomicity Logging used by all modern systems. Q: Why? Faloutsos/PavloCMU SCS 15-415/61524 A
25
CMU SCS Mechanisms for Ensuring Atomicity Logging used by all modern systems. Q: Why? A: Audit Trail & Efficiency Reasons What other mechanism can you think of? Faloutsos/PavloCMU SCS 15-415/61525 A
26
CMU SCS Mechanisms for Ensuring Atomicity Another approach: SHADOW PAGING –DBMS makes copies of pages and txns make changes to those copies. Only when the txn commits is the page made visible to others. –Originally from System R. Few systems do this: –CouchDB –LMDB (OpenLDAP) Faloutsos/PavloCMU SCS 15-415/61526 A
27
CMU SCS Overview Problem definition & ‘ACID’ A tomicity C onsistency I solation D urability Faloutsos/PavloCMU SCS 15-415/61527
28
CMU SCS Database Consistency Database Consistency: Data in the DBMS is accurate in modeling the real world and follows integrity constraints Faloutsos/PavloCMU SCS 15-415/61528 C
29
CMU SCS Transaction Consistency Transaction Consistency: if the database is consistent before the txn starts (running alone), it will be after also. Transaction consistency is the application’s responsibility. –We won’t discuss this further… Faloutsos/PavloCMU SCS 15-415/61529 C
30
CMU SCS Strong vs. Weak Consistency In a distributed DBMS, the consistency level determines when other nodes see new data in the database: – Strong: Guaranteed to see all writes immediately, but txns are slower. – Weak/Eventual: Will see writes at some later point in time, but txns are faster. Faloutsos/PavloCMU SCS 15-415/61530 C
31
CMU SCS Application Servers DBMS Servers Strong Consistency Faloutsos/PavloCMU SCS 15-415/61531 Master Replicas Update Profile Get Profile C
32
CMU SCS Application Servers DBMS Servers Eventual Consistency Faloutsos/PavloCMU SCS 15-415/61532 Master Replicas Update Profile Get Profile C ? ?
33
CMU SCS Overview Problem definition & ‘ACID’ A tomicity C onsistency I solation D urability Faloutsos/PavloCMU SCS 15-415/61533
34
CMU SCS Isolation of Transactions Users submit txns, and each txn executes as if it was running by itself. Concurrency is achieved by DBMS, which interleaves actions (reads/writes of DB objects) of various transactions. Q: How do we achieve this? Faloutsos/PavloCMU SCS 15-415/61534 I
35
CMU SCS Isolation of Transactions A: Many methods - two main categories: – Pessimistic – Don’t let problems arise in the first place. – Optimistic – Assume conflicts are rare, deal with them after they happen. Faloutsos/PavloCMU SCS 15-415/61535 I
36
CMU SCS Example Consider two txns: –T1 transfers $100 from B’s account to A’s – T2 credits both accounts with 6% interest. Faloutsos/PavloCMU SCS 15-415/61536 BEGIN A=A+100 B=B–100 COMMIT BEGIN A=A+100 B=B–100 COMMIT T1 BEGIN A=A*1.06 B=B*1.06 COMMIT BEGIN A=A*1.06 B=B*1.06 COMMIT T2 I
37
CMU SCS Example Assume at first A and B each have $1000. Q: What are the legal outcomes of running T1 and T2? Faloutsos/PavloCMU SCS 15-415/61537 BEGIN A=A+100 B=B–100 COMMIT BEGIN A=A+100 B=B–100 COMMIT T1 BEGIN A=A*1.06 B=B*1.06 COMMIT BEGIN A=A*1.06 B=B*1.06 COMMIT T2 I
38
CMU SCS Example Q: What are the possible outcomes of running T1 and T2 together? A: Many! But A+B should be: $2000*1.06=$2120 There is no guarantee that T1 will execute before T2 or vice-versa, if both are submitted together. But, the net effect must be equivalent to these two transactions running serially in some order. Faloutsos/PavloCMU SCS 15-415/61538 I
39
CMU SCS Example Legal outcomes: –A=1166, B=954 –A=1160, B=960 The outcome depends on whether T1 executes before T2 or vice versa. Faloutsos/PavloCMU SCS 15-415/61539 I →$2120
40
CMU SCS Serial Execution Example Faloutsos/PavloCMU SCS 15-415/61540 I ≡ A=1166, B=954A=1160, B=960 TIME BEGIN A=A+100 B=B–100 COMMIT T1 T2 BEGIN A=A*1.06 B=B*1.06 COMMIT BEGIN A=A+100 B=B–100 COMMIT T1 T2 BEGIN A=A*1.06 B=B*1.06 COMMIT Schedule
41
CMU SCS Interleaving Transactions We can also interleave the txns in order to maximize concurrency. –Slow disk/network I/O. –Multi-core CPUs. Faloutsos/PavloCMU SCS 15-415/61541 I
42
CMU SCS Interleaving Example (Good) Faloutsos/PavloCMU SCS 15-415/61542 I ≡ A=1166, B=954 TIME BEGIN A=A+100 B=B–100 COMMIT T1 T2 BEGIN A=A*1.06 B=B*1.06 COMMIT BEGIN A=A+100 B=B–100 COMMIT T1 T2 BEGIN A=A*1.06 B=B*1.06 COMMIT Schedule
43
CMU SCS Interleaving Example (Bad) Faloutsos/PavloCMU SCS 15-415/61543 I ≢ A=1166, B=960 TIME A=1166, B=954 or A=1160, B=960 BEGIN A=A+100 B=B–100 COMMIT T1 T2 BEGIN A=A*1.06 B=B*1.06 COMMIT Schedule The bank lost $6!
44
CMU SCS Interleaving Example (Bad) Faloutsos/PavloCMU SCS 15-415/61544 I Schedule A=1166, B=960 TIME DBMS’s View BEGIN R(A) W(A) R(B) W(B) COMMIT T1 T2 BEGIN R(A) W(A) R(B) W(B) COMMIT BEGIN A=A+100 B=B–100 COMMIT T1 T2 BEGIN A=A*1.06 B=B*1.06 COMMIT
45
CMU SCS Correctness Q: How do we judge that a schedule is correct? A: If it is equivalent to some serial execution Faloutsos/PavloCMU SCS 15-415/61545 I
46
CMU SCS Formal Properties of Schedules Serial Schedule: A schedule that does not interleave the actions of different transactions. Equivalent Schedules: For any database state, the effect of executing the first schedule is identical to the effect of executing the second schedule.* Faloutsos/PavloCMU SCS 15-415/61546 I (*) no matter what the arithmetic operations are!
47
CMU SCS Formal Properties of Schedules Serializable Schedule: A schedule that is equivalent to some serial execution of the transactions. Note: If each transaction preserves consistency, every serializable schedule preserves consistency. Faloutsos/PavloCMU SCS 15-415/61547 I
48
CMU SCS Formal Properties of Schedules Serializability is a less intuitive notion of correctness compared to txn initiation time or commit order, but it provides the DBMS with significant additional flexibility in scheduling operations. Faloutsos/PavloCMU SCS 15-415/61548 I
49
CMU SCS Interleaved Execution Anomalies Read-Write conflicts (R-W) Write-Read conflicts (W-R) Write-Write conflicts (W-W) Q: Why not R-R conflicts? Faloutsos/PavloCMU SCS 15-415/61549 I
50
CMU SCS Reading Uncommitted Data, “Dirty Reads”: BEGIN R(A) W(A) R(B) W(B) ABORT T1 T2 BEGIN R(A) W(A) COMMIT Write-Read Conflicts Faloutsos/PavloCMU SCS 15-415/61550 I $10 $12 $14
51
CMU SCS Read-Write Conflicts Unrepeatable Reads Faloutsos/PavloCMU SCS 15-415/61551 I BEGIN R(A) COMMIT T1 T2 BEGIN R(A) W(A) COMMIT $10 $19
52
CMU SCS Overwriting Uncommitted Data BEGIN W(A) W(B) COMMIT T1 T2 BEGIN W(A) W(B) COMMIT Write-Write Conflicts Faloutsos/PavloCMU SCS 15-415/61552 I $10 Christos $19 Bieber
53
CMU SCS Solution Q: How could you guarantee that all resulting schedules are correct (i.e., serializable)? A: Use locks! Faloutsos/PavloCMU SCS 15-415/61553 I
54
CMU SCS Executing without Locks Faloutsos/PavloCMU SCS 15-415/61554 I TIME BEGIN R(A) W(A) COMMIT T1 T2 BEGIN R(A) W(A) COMMIT
55
CMU SCS BEGIN LOCK(A) R(A) W(A) UNLOCK(A) COMMIT T1 T2 BEGIN LOCK(A) R(A) W(A) UNLOCK(A) COMMIT Executing with Locks Faloutsos/PavloCMU SCS 15-415/61555 I TIME Lock Manager Granted (T1→A) Denied! Granted (T2→A) Released (T1→A) Released (T2→A)
56
CMU SCS Executing with Locks Q: If a txn only needs to read ‘A’, should it still get a lock? A: Yes, but you can get a shared lock. Faloutsos/PavloCMU SCS 15-415/61556 I
57
CMU SCS Lock Types Basic Types: –S-LOCK – Shared Locks (reads) –X-LOCK – Exclusive Locks (writes) Faloutsos/PavloCMU SCS 15-415/61557 I SharedExclusive Shared ✔ X Exclusive XX Compatibility Matrix
58
CMU SCS Executing with Locks Transactions request locks (or upgrades) Lock manager grants or blocks requests Transactions release locks Lock manager updates lock-table But this is not enough… Faloutsos/PavloCMU SCS 15-415/61558 I
59
CMU SCS BEGIN X-LOCK(A) R(A) W(A) UNLOCK(A) S-LOCK(A) R(A) UNLOCK(A) COMMIT T1 T2 BEGIN X-LOCK(A) W(A) UNLOCK(A) COMMIT Executing with Locks Faloutsos/PavloCMU SCS 15-415/61559 I TIME Lock Manager Granted (T1→A) Granted (T2→A) Released (T1→A) Released (T2→A) Granted (T1→A) Released (T1→A)
60
CMU SCS Concurrency Control We need to use a well-defined protocol that ensures that txns execute correctly. Two categories: – Two-Phase Locking (2PL) – Timestamp Ordering (T/O) Faloutsos/PavloCMU SCS 15-415/61560 I We will discuss T/O methods in future classes. Pessimistic Optimistic
61
CMU SCS Two-Phase Locking Phase 1: Growing –Each txn requests the locks that it needs from the DBMS’s lock manager. –The lock manager grants/denies lock requests. Phase 2: Shrinking –The txn is allowed to only release locks that it previously acquired. It cannot acquire new locks. Faloutsos/PavloCMU SCS 15-415/61561
62
CMU SCS Two-Phase Locking The txn is not allowed to acquire/upgrade locks after the growing phase finishes. Faloutsos/PavloCMU SCS 15-415/61562 I Growing PhaseShrinking Phase TIME Transaction Lifetime
63
CMU SCS Two-Phase Locking The txn is not allowed to acquire/upgrade locks after the growing phase finishes. Faloutsos/PavloCMU SCS 15-415/61563 I Growing PhaseShrinking Phase TIME Transaction Lifetime 2PL Violation!
64
CMU SCS BEGIN X-LOCK(A) R(A) W(A) R(A) UNLOCK(A) COMMIT T1 T2 BEGIN X-LOCK(A) W(A) UNLOCK(A) COMMIT Executing with 2PL Faloutsos/PavloCMU SCS 15-415/61564 I TIME Lock Manager Granted (T1→A) Denied! Released (T2→A) Released (T1→A) Granted (T2→A)
65
CMU SCS 2PL Observations There are schedules that are serializable but would not be allowed by 2PL. Locking limits concurrency. May lead to deadlocks. May still have “dirty reads” –Solution: Strict 2PL Faloutsos/PavloCMU SCS 15-415/61565 I
66
CMU SCS Strict Two-Phase Locking A schedule is strict if a value written by a txn is not read or overwritten by other txns until that txn finishes. Advantages: –Recoverable. –Do not require cascading aborts. –Aborted txns can be undone by just restoring original values of modified tuples. Faloutsos/PavloCMU SCS 15-415/61566 I
67
CMU SCS Strict Two-Phase Locking Txns hold all of their locks until commit. Good: –Avoids “dirty reads” etc Bad: –Limits concurrency even more –And still may lead to deadlocks Faloutsos/PavloCMU SCS 15-415/61567 I
68
CMU SCS Strict Two-Phase Locking The txn is not allowed to acquire/upgrade locks after the growing phase finishes. Faloutsos/PavloCMU SCS 15-415/61568 I Growing PhaseShrinking Phase TIME Transaction Lifetime
69
CMU SCS Q: Why is avoiding “dirty reads” important? Strict Two-Phase Locking Faloutsos/PavloCMU SCS 15-415/61569 I BEGIN R(A) W(A) R(B) W(B) ABORT T1 T2 BEGIN R(A) W(A) COMMIT $10 $12
70
CMU SCS Strict Two-Phase Locking Q: Why is avoiding “dirty reads” important? A: If a txn aborts, all actions must be undone. Any txn that read modified data must also be aborted. Faloutsos/PavloCMU SCS 15-415/61570 I
71
CMU SCS Locking in Practice You typically don’t set locks manually. Sometimes you will need to provide the DBMS with hints to help it to improve concurrency. Also useful for doing major changes. Faloutsos/PavloCMU SCS 15-415/61571 I
72
CMU SCS Overview Problem definition & ‘ACID’ A tomicity C onsistency I solation D urability Faloutsos/PavloCMU SCS 15-415/61572
73
CMU SCS Transaction Durability Records are stored on disk. For updates, they are copied into memory and flushed back to disk at the discretion of the O.S. –Unless forced-output: W(B)→fsync() Faloutsos/PavloCMU SCS 15-415/61573 D This is slow! Nobody does this!
74
CMU SCS Transaction Durability Faloutsos/PavloCMU SCS 15-415/61574 BEGIN R(A) W(A) ⋮ COMMIT T1 D Buffer Pool Disk A=1 Page A=1 Memory
75
CMU SCS Transaction Durability Faloutsos/PavloCMU SCS 15-415/61575 BEGIN R(A) W(A) ⋮ COMMIT T1 D Buffer Pool Disk A=1 Page A=2 Memory Buffer is added to output queue but is not flushed immediately
76
CMU SCS Write-Ahead Log Record the changes made to the database in a log before the change is made. Assume that the log is on stable storage. Q: What to replicate? –The complete page? –Single tuple? Faloutsos/PavloCMU SCS 15-415/61576 D
77
CMU SCS Write-Ahead Log Log record format: – –Each transaction writes a log record first, before doing the change When a txn finishes, the DBMS will: –Write a record on the log –Make sure that all log records are flushed before it returns an acknowledgement to application. Faloutsos/PavloCMU SCS 15-415/61577 D
78
CMU SCS Write-Ahead Log After a failure, DBMS “replays” the log: –Undo uncommited transactions –Redo the committed ones Faloutsos/PavloCMU SCS 15-415/61578 D
79
CMU SCS BEGIN W(A) W(B) ⋮ COMMIT T1 Write-Ahead Log Faloutsos/PavloCMU SCS 15-415/61579 D ⋮ CRASH! Before Value After Value TxnIdObjectId The DBMS hasn’t flushed memory to disk at this point. We have to redo T1! Safe to return result to application.
80
CMU SCS Write-Ahead Log Faloutsos/PavloCMU SCS 15-415/61580 D ⋮ CRASH! BEGIN W(A) W(B) ⋮ COMMIT T1 We have to undo T1
81
CMU SCS Recovering After a Crash At the end – all committed updates and only those updates are reflected in the database. Some care must be taken to handle the case of a crash occurring during the recovery process! Faloutsos/PavloCMU SCS 15-415/61581 D
82
CMU SCS WAL Problems The log grows infinitely… We have to take checkpoints to reduce the amount of processing that we need to do. We will discuss this in further detail in upcoming classes. Faloutsos/PavloCMU SCS 15-415/61582
83
CMU SCS ACID Properties Atomicity: All actions in the txn happen, or none happen. Consistency: If each txn is consistent, and the DB starts consistent, it ends up consistent. Isolation: Execution of one txn is isolated from that of other txns. Durability: If a txn commits, its effects persist. Faloutsos/PavloCMU SCS 15-415/61583
84
CMU SCS Summary Concurrency control and recovery are among the most important functions provided by a DBMS. Concurrency control is automatic –System automatically inserts lock/unlock requests and schedules actions of different txns. –Ensures that resulting execution is equivalent to executing the txns one after the other in some order. Faloutsos/PavloCMU SCS 15-415/61584
85
CMU SCS Summary Write-ahead logging (WAL) and the recovery protocol are used to: –Undo the actions of aborted transactions. –Restore the system to a consistent state after a crash. Faloutsos/PavloCMU SCS 15-415/61585
86
CMU SCS Overview A tomicity C onsistency I solation D urability Faloutsos/PavloCMU SCS 15-415/61586 Recovery Concurrency Control
Similar presentations
© 2025 SlidePlayer.com Inc.
All rights reserved.