1. Trang chủ
  2. » Công Nghệ Thông Tin

Dbms chapter 6 concurrency control techniques

84 2 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Tiêu đề Concurrency control techniques
Người hướng dẫn Dr. Võ Thị Ngọc Châu
Trường học Ho Chi Minh City University of Technology
Chuyên ngành Database Management Systems
Thể loại Bài giảng
Năm xuất bản 2020-2021
Thành phố Ho Chi Minh City
Định dạng
Số trang 84
Dung lượng 2,62 MB

Các công cụ chuyển đổi và chỉnh sửa cho tài liệu này

Nội dung

Concurrency control techniques  The two-phase locking technique of locking data items to prevent multiple transactions from accessing the items concurrently  Multiversion concurrenc

Trang 1

Chapter 6: Concurrency Control

Trang 2

2

Course outline

 Chapter 1 Overall Introduction to Database

Management Systems

 Chapter 2 Disk Storage and Basic File Structures

 Chapter 3 Indexing Structures for Files

 Chapter 4 Query Processing and Optimization

 Chapter 5 Introduction to Transaction Processing Concepts and Theory

Chapter 6 Concurrency Control Techniques

 Chapter 7 Database Recovery Techniques

Trang 3

3

References

 [1] R Elmasri, S R Navathe, Fundamentals of Database

Systems- 6th Edition, Pearson- Addison Wesley, 2011

R Elmasri, S R Navathe, Fundamentals of Database Systems- 7th Edition, Pearson, 2016

 [2] H G Molina, J D Ullman, J Widom, Database System

Implementation, Prentice-Hall, 2000

 [3] H G Molina, J D Ullman, J Widom, Database Systems: The Complete Book, Prentice-Hall, 2002

 [4] A Silberschatz, H F Korth, S Sudarshan, Database

System Concepts –3rd Edition, McGraw-Hill, 1999

 [Internet] …

Trang 4

Techniques

Granularity Locking Technique

4

Trang 5

6.1 Purposes Of Concurrency Control

among conflicting transactions;

consistency preserving execution of transactions;

the A and if the other transaction is rolled-back or

waits

5

Trang 6

Concurrency control techniques

 The two-phase locking technique of locking data items to

prevent multiple transactions from accessing the items

concurrently

 Multiversion concurrency control

 Concurrency control protocols that use timestamps

 Multiversion concurrency control

 A protocol based on the concept of validation or certification

of a transaction after it executes its operations

 Multiple granularity level two-phase locking protocol

6

Trang 7

Two-Phase Locking Techniques

Locking is an operation which secures (a) permission

to read or (b) permission to write a data item for a

Trang 8

Based on the concept of locking data items to

guarantee serializability of transaction schedules

shrinking (second) phase

A transaction is said to follow the two-phase locking

protocol (i.e well-formed) if all locking operations precede the first unlock operation in the transaction

8

Expanding/growing (first) phase Locking data items

Shrinking (second) phase Unlocking data items

Transaction T that follows the

two-phase locking protocol

6.2 Two-Phase Locking

Trang 9

A lock is a variable associated with a data

item that describes the status of the item

with respect to possible operations that can

be applied to it

concurrent transactions to the database items

(or read/write) locks, certify locks

6.2 Two-Phase Locking

Trang 10

 Binary locks

LOCK(X), then item X cannot be accessed by a

database operation (read/write) that requests the item

can be accessed when requested

data item

 At most one transaction can hold the lock on a data item

6.2 Two-Phase Locking

Trang 11

11

Figure 21.1 Lock and unlock operations for binary locks

[1], pp 783

6.2 Two-Phase Locking

Trang 12

 Every transaction must obey the following

rules in the binary locking scheme:

lock_item(X) before any read_item(X) or

write_item(X) operations are performed in T

unlock_item(X) after all read_item(X) and

write_item(X) operations are completed in T

operation if it already holds the lock on item X

operation unless it already holds the lock on item X

6.2 Two-Phase Locking

Trang 13

 Shared/Exclusive (Read/Write) locks

Read-locked: share-locked  other transactions are

allowed to read the item

Write-locked: exclusive-locked  a single transaction

exclusively holds the lock on the item

write_lock(X), unlock(X)

13

6.2 Two-Phase Locking

Trang 17

 Every transaction must obey the following rules in the

shared/exclusive locking scheme:

 1 A transaction T must issue the operation read_lock(X) or

write_lock(X) before any read_item(X) operation is performed in T

 2 A transaction T must issue the operation write_lock(X) before any write_item(X) operation is performed in T

 3 A transaction T must issue the operation unlock(X) after all

read_item(X) and write_item(X) operations are completed in T

 4 A transaction T will not issue a read_lock(X) operation if it already holds a read (shared) lock or a write (exclusive) lock on item X

 5 A transaction T will not issue a write_lock(X) operation if it already holds a read (shared) lock or write (exclusive) lock on item X

 6 A transaction T will not issue an unlock(X) operation unless it

already holds a read (shared) lock or a write (exclusive) lock on item

X

Note: Rules 4 & 5 may be relaxed for lock conversion 17

6.2 Two-Phase Locking

Trang 18

 Conversion of locks

is allowed under certain conditions to convert the lock from one locked state to another

 None of other transactions holds a lock on X

used, the lock table must include transaction

identifiers in the record structure for each lock to

store the information on which transactions hold

6.2 Two-Phase Locking

Trang 19

 Two-phase locking protocols

A transaction is said to follow the two-phase locking protocol if all

locking operations (read_lock, write_lock) precede the first unlock

operation in the transaction

Such a transaction can be divided into two phases: an expanding

or growing (first) phase, during which new locks on items can

be acquired but none can be released; a shrinking (second)

phase, during which existing locks can be released but no new

locks can be acquired

 If lock conversion is allowed, then upgrading of locks must be

done during the expanding phase, and downgrading of locks must

be done in the shrinking phase

If every transaction in a schedule follows the two-phase locking

protocol, the schedule is guaranteed to be serializable

 When to lock data items?

 When to unlock data items?

19

6.2 Two-Phase Locking

Trang 20

20

 Lock Manager: Managing locks on data items

 Lock Table: a table that stores the identity of

transaction locking (the data item, lock mode and pointer to the next data item locked) One simple way to implement a lock table is through linked lists

Trang 21

21

Figure 21.3 Transactions that do not obey two-phase locking

[1], pp 787

6.2 Two-Phase Locking

Trang 22

22

6.2 Two-Phase Locking

Trang 24

 Variations of two-phase locking (2PL)

 Basic 2PL

 Conservative 2PL (static 2PL)

A transaction locks all the items it accesses before the transaction

begin execution, by predeclaring its read-set and write-set If any of the predeclared items needed cannot be locked, the transaction does not lock any item This is a deadlock-free protocol

 Strict 2PL

A transaction T does not release any of its exclusive (write) locks until

after it commits or aborts Hence, no other transaction can read or

write an item that is written by T unless T has committed, leading to a strict schedule for recoverability This is not deadlock-free

Trang 25

 Deadlock

of two or more transactions is waiting for some

item that is locked by some other transaction T‟ in the set

transaction locks only a few items; the transaction load is

6.2 Two-Phase Locking

Trang 26

to wait; otherwise Ti dies and is restarted with the same timestamp

 Wound-wait: If Ti is older than Tj, Ti wounds Tj, abort Tj and restart it

later with the same timestamp; otherwise, Ti is allowed to wait

 Deadlock prevention schemes that do not require timestamps: waiting & cautious-waiting

no- No-waiting: if a transaction is unable to obtain a lock, it is immediately aborted and then restarted after a certain time delay without checking whether a deadlock will actually occur or not

 Cautious-waiting: if Tj is not blocked (not waiting for some other locked item), then Ti is blocked and allowed to wait; otherwise abort Ti

26

6.2 Two-Phase Locking

Trang 27

 Deadlock detection

exists

transactions causing the deadlock must be aborted

victim selection

 Avoid selecting transactions that have been running for a long time and that have performed many updates

system to construct and maintain a wait-for graph

27

6.2 Two-Phase Locking

Trang 28

 Deadlock detection

 One node is created for each transaction that is currently executing

 A directed edge (Ti  Tj) is created whenever a transaction Ti is waiting to lock an item X that is currently locked by a transaction Tj

 The directed edge (Ti  Tj) is dropped when Tj releases the lock(s) on the items that Ti was waiting for

A state of deadlock if and only if the wait-for graph has

a cycle

28

6.2 Two-Phase Locking

Trang 29

29

(b)

Figure 21.5 Illustrating the deadlock problem

(a) A partial schedule of T1‟ and T2‟ that is in a state of deadlock

(b) A wait-for graph for the partial schedule in (a)

[1], pp 790

DEADLOCK!

6.2 Two-Phase Locking

Trang 30

 A fair waiting scheme

 Using a first-come-first-served queue; transactions are enabled to lock an item in the order in which they originally requested the lock

 Priority-based schemes

 Wait-die and wound-wait schemes

30

6.2 Two-Phase Locking

Trang 31

6.3 Concurrency Control Based On Timestamp Ordering

 Guarantees serializability by using transaction timestamps to order transaction execution for

an equivalent serial schedule

based on their timestamps

operations, the order in which the item is accessed

does not violate the serializability order

31

Trang 32

 Transaction timestamp - TS(T): a unique identifier

to identify a transaction T, assigned in the order in which the transaction is submitted to the system

largest timestamp among all the timestamps of

transactions that have successfully read item X –

that is, read_TS(X) = TS(T), where T is the

youngest transaction that has read X successfully

largest of all the timestamps of transactions that

have successfully written item X – that is,

write_TS(X) = TS(T), where T is the youngest

6.3 Concurrency Control Based On Timestamp Ordering

Trang 33

 The basic timestamp ordering algorithm

 Check if conflicting operations violate the timestamp ordering

 Schedules are guaranteed to be conflict serializable

 1 Transaction T issues a write_item(X) operation

 If read_TS(X) > TS(T) or if write_TS(X) > TS(T), then abort and roll back T and reject the operation because some younger transaction with

a timestamp greater than TS(T) – and hence, after T in the timestamp ordering – has already read or written the value of item X before T had a chance to write X, thus violating the timestamp ordering

 Otherwise, execute the write_item(X) operation of T and set write_TS(X)

to TS(T)

 2 Transaction T issues a read_item(X) operation

 If write_TS(X) > TS(T), then abort and roll back T and reject the operation because some younger transaction with timestamp greater than TS(T) – and hence, after T

in the timestamp ordering – has already written the value of item X before T had a chance to read X

 Otherwise, execute the read_item(X) operation of T and set read_TS(X) to the larger of TS(T) and the current read_TS(X) 33

6.3 Concurrency Control Based On Timestamp Ordering

Trang 34

34

Timestamp TS = 1 TS = 2 Write_TS = 0 Read_TS = 0 Write_TS = 0 Read_TS = 0

Read_item(X) Read_item(X) Write_item(X) Write_item(X) Read_item(Y)

Trang 35

Write_item(X) of T1 is rejected, T1 is aborted: Read_TS(X) > TS(T1)

Schedule C (Figure 20.5.c) is non-serializable

6.3 Concurrency Control Based On Timestamp Ordering

Trang 36

Schedule D (Figure 20.5.d) is conflict serializable

6.3 Concurrency Control Based On Timestamp Ordering

Trang 37

 Strict timestamp ordering

recoverability) and conflict serializable

write_item(X) such that TS(T) > write_TS(X) has

its read or write operation delayed until the

transaction T‟ that wrote the value of X (hence,

TS(T‟) = write_TS(X)) has committed or aborted

37

6.3 Concurrency Control Based On Timestamp Ordering

Trang 38

 Thomas‟s Write Rule

algorithm that does not enforce conflict

serializability; but rejects fewer write operations

 1 If read_TS(X) > TS(T), then abort and roll back T and reject the operation

 2 If write_TS(X) > TS(T), then do not execute the write operation but continue processing This is because some transaction with timestamp greater than TS(T) – and hence, after T in the timestamp ordering – has already written the value of X

 3 Otherwise, execute the write_item(X) operation of T and set write_TS(X) to TS(T) 38

6.3 Concurrency Control Based On Timestamp Ordering

Trang 39

6.4 Multiversion

concurrency control techniques

new version (new value) and the old version (old value) of the item is maintained

item, an appropriate version is chosen to

maintain the serializability of the currently

executing schedule

reading an older version of the item to

Trang 40

6.4 Multiversion

concurrency control techniques

 Several versions X1, X2, …, Xk of each data item X are

maintained

 For each version, the value of version Xi and the two timestamps are kept:

 Read_TS(Xi): the largest of all the timestamps of

transactions that have successfully read version Xi

 Write_TS(Xi): the timestamp of the transaction that wrote the value of version Xi

 Whenever a transaction T is allowed to execute a

write_item(X) operation, a new version Xk+1 of item X is

created, with both the write_TS(Xk+1) and the read_TS(Xk+1) set to TS(T)

40

Trang 41

6.4 Multiversion

concurrency control techniques

To ensure serializability, the following two rules are used:

1 If transaction T issues a write_item(X) operation, and

version i of X has the highest write_TS(Xi) of all versions of X

that is also less than or equal to TS(T), and read_TS(Xi) >

TS(T), then abort and roll back transaction T; otherwise, create

a new version Xj of X with read_TS(Xj) = write_TS(Xj) = TS(T)

2 If transaction T issues a read_item(X) operation, find the

version i of X that has the highest write_TS(Xi) of all versions

of X that is also less than or equal to TS(T); then return the

value of Xi to transaction T, and set the value of read_TS(Xi) to the larger of TS(T) and the current read_TS(Xi) 41

Trang 42

6.4 Multiversion

concurrency control techniques

Trang 43

What happens with the W1(Y) operation of transaction T1?

Trang 45

Your turn: perform concurrency control on this schedule using the

traditional timestamp ordering technique and then the multiversion one

Trang 48

Your turn: perform concurrency control on this schedule using the

traditional timestamp ordering technique and then the multiversion one

Trang 49

Your turn: perform concurrency control on this schedule using the

traditional timestamp ordering technique

Trang 50

Write_TS =

150

Read_TS = 200;

Write_TS =

200

Read_TS = 175;

Write_TS =

175

Read_TS=0

; Write_TS=

0

Read_TS = 200;

Write_TS =

200

Read_TS= 0; Write_TS=

Your turn: perform concurrency control on this schedule using the

multiversion timestamp ordering technique

Trang 51

6.4 Multiversion

concurrency control techniques

 A multiple-mode locking scheme

 Three locking modes for an item: read, write, certify

 State of LOCK(X) for an item X: read-locked, write-locked, certify-locked, or unlocked

51

Figure 21.6 Lock compatibility tables

(a) A compatibility table for read/write locking scheme

(b) A compatibility table for read/write/certify locking scheme

[1], pp 797

Ngày đăng: 06/04/2023, 09:30