Q: which locks mysql has
High concurrency can cause several data problems
1.1 dirty read
An uncommitted problem with one transaction reading another
To prevent dirty reads, add an exclusive lock (write lock) when modifying a dirty read, which is not released until the transaction is committed, and add a shared lock (read lock) when reading. Other transactions can only read, and no update operation can be performed
1.2 Unrepeatable Read
In the same transaction, the same data is read twice, and the content is different
MVCC multi-version concurrency control, when executing a query, the current query version number >= create version number and > delete version number, MVCC can in most cases instead of row level lock, using MVCC, can reduce its system overhead
1.3 phantom read
In the same transaction, the same operation is read twice, and the number of records is different
Mysql official phantom reads the explanation is: as long as in a transaction, the second row even more select phantom reads
1.4 Row lock Table lock and page lock
Row-level locks are the most fine-grained locks in mysql. Indicates that only the current row is locked. Row-level locking can greatly reduce the conflicts of database operations. It has the smallest granularity and the largest cost of locking. Row – level locks are divided into shared locks and exclusive locks
Table level lock is the most granular lock in mysql, which means to lock the entire table of the current operation. It is simple to implement, consumes less resources, and is supported by most mysql engines. The most commonly used MyISAM and InnoDB both support table-level locking
Page level lock is a lock in MySQL that is between row level lock and table level lock. Table-level locking is fast but has more conflicts, and row-level locking is slow but has less conflicts. Therefore, a compromise page level lock is adopted, locking an adjacent set of records at a time. BDB supports page-level locking
Two lock judgment and scene
1.1 Several isolation levels for database transactions
Mysql database supports transactions if and only if InnoDB is the engine.
The transaction isolation level can be read Uncommitted, Read COMMITTED, repeatable Read, and Serializable.
Uncommitted read: A transaction is executed but not committed; Transaction B queries the updated data of transaction A; A Transaction rollback; — Dirty data appears
Committed read: A transaction performs update; B transaction query; A transaction performs updates; B When the transaction is queried again, the data is inconsistent before and after the query. — It cannot be read repeatedly
Repeatable read: no matter how many times transaction A is executed, as long as transaction B is not committed, the query value of transaction B remains unchanged; Transaction B queries only the data snapshot at the beginning of transaction B.
Serialization: concurrent read/write operations are not allowed. While a write is executed, the read must wait.
What we often use is repeatable read
1.2 Viewing the Isolation Level of the Current Transaction
// SELECT @@tx_isolation;Copy the code
At the moment, it’s reread
// Set the read UNCOMMITTED level: set session TRANSACTION isolation level Read UNCOMMITTED; // Check the lock log. SHOW ENGINE INNODB STATUS;Copy the code
1.3 Deadlock occurs when the following transaction situations occur
1.4 Let’s look at the lock log
------------------------
LATEST DETECTED DEADLOCK
------------------------
190219 13:35:31
*** (1) TRANSACTION:
TRANSACTION 2A8BD, ACTIVE 11 sec starting index read
mysql tables in use 1, locked 1
LOCK WAIT 2 lock struct(s), heap size 376, 1 row lock(s)
MySQL thread id 448218, OS thread handle 0x2abe5fb5d700, query id 18923238 renjun.fangcloud.net 121.41.41.92 root updating
delete from test where a = 2
*** (1) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 0 page no 923 n bits 80 index `a` of table `oauthdemo`.`test` trx id 2A8BD lock_mode X waiting
Record lock, heap no 3 PHYSICAL RECORD: n_fields 2; compact format; info bits 32
0: len 4; hex 00000002; asc ;;
1: len 4; hex 00000002; asc ;;
*** (2) TRANSACTION:
TRANSACTION 2A8BC, ACTIVE 18 sec inserting
mysql tables in use 1, locked 1
4 lock struct(s), heap size 1248, 3 row lock(s), undo log entries 2
MySQL thread id 448217, OS thread handle 0x2abe5fd65700, query id 18923239 renjun.fangcloud.net 121.41.41.92 root update
insert into test (id,a) values (10,2)
*** (2) HOLDS THE LOCK(S):
RECORD LOCKS space id 0 page no 923 n bits 80 index `a` of table `oauthdemo`.`test` trx id 2A8BC lock_mode X locks rec but not gap
Record lock, heap no 3 PHYSICAL RECORD: n_fields 2; compact format; info bits 32
0: len 4; hex 00000002; asc ;;
1: len 4; hex 00000002; asc ;;
*** (2) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 0 page no 923 n bits 80 index `a` of table `oauthdemo`.`test` trx id 2A8BC lock mode S waiting
Record lock, heap no 3 PHYSICAL RECORD: n_fields 2; compact format; info bits 32
0: len 4; hex 00000002; asc ;;
1: len 4; hex 00000002; asc ;;
Copy the code
Delete from test where a = 2 = 1
! [](https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/22f6aa22183a4bfea9e6cc4fa496c69e~tplv-k3u1fbpfcp-zoom-1.image)
In THE holding THE LOCKS(S) block of THE log we can see that transaction 2 HOLDS THE X Lock of index A and is a Record Lock. The lock is obtained through the DELETE statement executed in Transaction 2 in Step 2. Since this is an equivalent query based on a unique index (Where a = 2) in RR isolation mode, a record lock is applied instead of a next-key lock.
From the log block WAITING FOR THIS LOCK TO BE GRANTED we can see that transaction 2 is requesting S LOCK, which is the shared LOCK. The lock was requested by the insert into test (id,a) values (10,2) statement. Insert statements normally apply for an exclusive lock, i.e., an X lock, but there is an S lock. This is because field A is a unique index, so the INSERT statement will check duplicate key once before insert. In order to make this check successful, it is necessary to apply S lock to prevent other transactions from modifying field A.
So why does the S lock fail? This means that requests for locks on the same field are queued. In front of lock S, there is an X lock that has not been applied successfully, so lock S must wait, so a circular wait is formed, and a deadlock occurs.
By reading the deadlock log, we can see exactly what kind of circular wait occurs between two transactions, and then by analyzing it, we can infer backwards the cause of the circular wait, which is the cause of the deadlock
Three deadlock
1.1 What is deadlock?
Deadlock: When two or more processes are in the process of execution.
The competition for resources creates a kind of waiting for each other, and without external forces, they can’t move forward. At this time, the system is said to be in a deadlock state or the system has produced a deadlock. These processes that are always waiting for each other are called deadlock processes. Table level locking does not produce deadlocks. So deadlock resolution is mainly for InnoDB, the most commonly used. The key to a deadlock is that two or more sessions are not locked in the same order. The key to solving the deadlock problem is to have different sessions lock in order.
1.2 Deadlock solutions
Kill the detected thread kill SELECT trx_MySQL_thread_id FROM information_schema.innodb_trx
Set lock timeout The time Innodb waits for a row lock, in seconds. This parameter can be set at the session level, and the default value for RDS instances is 50 seconds. It is not recommended to use large innodb_lock_wait_timeout values in production environments. This parameter can be modified at the session level. It is convenient to set the row lock wait timeout for special operations separately at the session level, as follows: set innodb_lock_wait_timeout=1000; – Set the Innodb row lock timeout period for the current session, in seconds.
Specifies the order in which locks are acquired
More information support to be updated……