В предыдущих статьях было представлено использование исходного кода для отладки информации, связанной с блокировкой.Этот инструмент также используется здесь для решения реального случая взаимоблокировки в сети, что также является первыми двумя SQL-запросами, которые мы представили, чтобы вызвать взаимоблокировку. Поскольку структура онлайн-таблицы более сложная, после некоторых упрощений делается следующее:
CREATE TABLE `t3` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`a` varchar(5),
`b` varchar(5),
PRIMARY KEY (`id`),
UNIQUE KEY `uk_a` (`a`),
KEY `idx_b` (`b`)
)
INSERT INTO `t3` (`id`, `a`, `b`) VALUES
(1,'1','2');
# sql语句如下
# 事务1:t1
update t3 set b = '' where a = "1";
# 事务2:t2
update t3 set b = '' where b = "2";
Трудно воспроизвести взаимоблокировку, вызванную двумя операторами вручную, давайте сначала проанализируем процесс блокировки.
Первый оператор (для обновления записи через уникальный индекс)
update t3 set b = '' where a = "1";
серийный номер | показатель | тип замка |
---|---|---|
1 | uk_a | X |
2 | PRIMARY | X |
3 | idx_b | X |
второе утверждение
update t3 set b = '' where b = "2";
серийный номер | показатель | тип замка |
---|---|---|
1 | idx_b | X |
2 | PRIMARY | X |
3 | idx_b | X |
Из последовательности блокировки два оператора уже имеют условия, образующие взаимоблокировку.
Это сложно смоделировать вручную.Напишите код для одновременного выполнения двух операторов SQL, и взаимоблокировка произойдет немедленно.
------------------------
LATEST DETECTED DEADLOCK
------------------------
181102 12:45:05
*** (1) TRANSACTION:
TRANSACTION 50AF, ACTIVE 0 sec starting index read
mysql tables in use 1, locked 1
LOCK WAIT 3 lock struct(s), heap size 376, 2 row lock(s)
MySQL thread id 34, OS thread handle 0x70000d842000, query id 549 localhost 127.0.0.1 root Searching rows for update
update t3 set b = '' where b = "2"
*** (1) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 67 page no 3 n bits 72 index `PRIMARY` of table `d1`.`t3` trx id 50AF lock_mode X locks rec but not gap waiting
Record lock, heap no 2 PHYSICAL RECORD: n_fields 5; compact format; info bits 0
0: len 4; hex 80000001; asc ;;
1: len 6; hex 0000000050ae; asc P ;;
2: len 7; hex 03000001341003; asc 4 ;;
3: len 1; hex 31; asc 1;;
4: len 0; hex ; asc ;;
*** (2) TRANSACTION:
TRANSACTION 50AE, ACTIVE 0 sec updating or deleting
mysql tables in use 1, locked 1
4 lock struct(s), heap size 1248, 3 row lock(s), undo log entries 1
MySQL thread id 35, OS thread handle 0x70000d885000, query id 548 localhost 127.0.0.1 root Updating
update t3 set b = '' where a = "1"
*** (2) HOLDS THE LOCK(S):
RECORD LOCKS space id 67 page no 3 n bits 72 index `PRIMARY` of table `d1`.`t3` trx id 50AE lock_mode X locks rec but not gap
Record lock, heap no 2 PHYSICAL RECORD: n_fields 5; compact format; info bits 0
0: len 4; hex 80000001; asc ;;
1: len 6; hex 0000000050ae; asc P ;;
2: len 7; hex 03000001341003; asc 4 ;;
3: len 1; hex 31; asc 1;;
4: len 0; hex ; asc ;;
*** (2) WAITING FOR THIS LOCK TO BE GRANTED:
RECORD LOCKS space id 67 page no 5 n bits 72 index `idx_b` of table `d1`.`t3` trx id 50AE lock_mode X locks rec but not gap waiting
Record lock, heap no 2 PHYSICAL RECORD: n_fields 2; compact format; info bits 0
0: len 1; hex 32; asc 2;;
1: len 4; hex 80000001; asc ;;
*** WE ROLL BACK TRANSACTION (1)
Анализ журнала взаимоблокировок
*** (1) WAITING FOR THIS LOCK TO BE GRANTED: RECORD LOCKS space id 67 page no 3 n bits 72 index
PRIMARY
of tabled1
.t3
trx id 50AF lock_mode X locks rec but not gap waiting
Транзакция 2: хотите получить блокировку X для индекса первичного ключа
*** (2) HOLDS THE LOCK(S): RECORD LOCKS space id 67 page no 3 n bits 72 index
PRIMARY
of tabled1
.t3
trx id 50AE lock_mode X locks rec but not gap
Транзакция 1: удерживает блокировку X на индексе первичного ключа
*** (2) WAITING FOR THIS LOCK TO BE GRANTED: RECORD LOCKS space id 67 page no 5 n bits 72 index
idx_b
of tabled1
.t3
trx id 50AE lock_mode X locks rec but not gap waiting
Транзакция 1: хотите получить блокировку X на обычном индексе idx_b
Это точно так же, как наш анализ, и это точно так же, как онлайн-журнал взаимоблокировок.