------------------------LATEST DETECTED DEADLOCK------------------------2021-11-10 17:03:10 0x7fb040672700*** (1) TRANSACTION:TRANSACTION 46913, ACTIVE 142 sec starting index readmysql tables in use 1, locked 1LOCK WAIT 4 lock struct(s), heap size 1136, 3 row lock(s), undo log entries 1MySQL thread id 2997198, OS thread handle 140394973071104, query id 9145673 localhost root updatingupdate test_tb set stu_name = 'lisi' where stu_id = 1006*** (1) WAITING FOR THIS LOCK TO BE GRANTED:RECORD LOCKS space id 224 page no 4 n bits 80 index uk_stu_id of table `testdb`.`test_tb` trx id 46913 lock_mode X locks rec but not gap waitingRecord lock, heap no 7 PHYSICAL RECORD: n_fields 2; compact format; info bits 0 0: len 4; hex 800003ee; asc ;; 1: len 4; hex 80000006; asc ;;
*** (2) TRANSACTION:TRANSACTION 46914, ACTIVE 103 sec starting index readmysql tables in use 1, locked 14 lock struct(s), heap size 1136, 3 row lock(s), undo log entries 1MySQL thread id 2997201, OS thread handle 140394971473664, query id 9145681 localhost root updatingupdate test_tb set age = 21 where stu_id = 1005*** (2) HOLDS THE LOCK(S):RECORD LOCKS space id 224 page no 4 n bits 80 index uk_stu_id of table `testdb`.`test_tb` trx id 46914 lock_mode X locks rec but not gapRecord lock, heap no 7 PHYSICAL RECORD: n_fields 2; compact format; info bits 0 0: len 4; hex 800003ee; asc ;; 1: len 4; hex 80000006; asc ;;
*** (2) WAITING FOR THIS LOCK TO BE GRANTED:RECORD LOCKS space id 224 page no 4 n bits 80 index uk_stu_id of table `testdb`.`test_tb` trx id 46914 lock_mode X locks rec but not gap waitingRecord lock, heap no 6 PHYSICAL RECORD: n_fields 2; compact format; info bits 0 0: len 4; hex 800003ed; asc ;; 1: len 4; hex 80000005; asc ;;
*** WE ROLL BACK TRANSACTION (2)
# 以上为原文 下面增加个人分析------------------------LATEST DETECTED DEADLOCK------------------------2021-11-10 17:03:10 0x7fb040672700 #这里显示了最近一次发生死锁的日期和时间*** (1) TRANSACTION: #死锁相关的第一个事务TRANSACTION 46913, ACTIVE 142 sec starting index read#这行表示事务id为46913,事务处于活跃状态142s,starting index read表示正在使用索引读取数据行mysql tables in use 1, locked 1#这行表示该事务正在使用1个表,且涉及锁的表有1个LOCK WAIT 4 lock struct(s), heap size 1136, 3 row lock(s), undo log entries 1#这行表示在等待4把锁,占用内存1136字节,涉及3行记录MySQL thread id 2997198, OS thread handle 140394973071104, query id 9145673 localhost root updating#这行表示该事务的线程ID信息,操作系统句柄信息,连接来源、用户update test_tb set stu_name = 'lisi' where stu_id = 1006#这行表示事务执行的最后一条SQL信息*** (1) WAITING FOR THIS LOCK TO BE GRANTED: #事务1想要获取的锁RECORD LOCKS space id 224 page no 4 n bits 80 index uk_stu_id of table `testdb`.`test_tb` trx id 46913 lock_mode X locks rec but not gap waiting#这行信息表示等待的锁是一个record lock,空间id是224,页编号为4,大概位置在页的80位处,锁发生在表testdb.test_tb的uk_stu_id索引上,是一个X锁,但是不是gap lock,waiting表示正在等待锁Record lock, heap no 7 PHYSICAL RECORD: n_fields 2; compact format; info bits 0 0: len 4; hex 800003ee; asc ;; 1: len 4; hex 80000006; asc ;;
*** (2) TRANSACTION: #死锁相关的第一个事务TRANSACTION 46914, ACTIVE 103 sec starting index read#这行表示事务2的id为46914,事务处于活跃状态103smysql tables in use 1, locked 1#正在使用1个表,涉及锁的表有1个4 lock struct(s), heap size 1136, 3 row lock(s), undo log entries 1#涉及4把锁,3行记录MySQL thread id 2997201, OS thread handle 140394971473664, query id 9145681 localhost root updating#事务2的线程ID信息,操作系统句柄信息,连接来源、用户update test_tb set age = 21 where stu_id = 1005#第二个事务的SQL*** (2) HOLDS THE LOCK(S): # 事务2持有的锁 正是事务1想要获取的锁RECORD LOCKS space id 224 page no 4 n bits 80 index uk_stu_id of table `testdb`.`test_tb` trx id 46914 lock_mode X locks rec but not gapRecord lock, heap no 7 PHYSICAL RECORD: n_fields 2; compact format; info bits 0 0: len 4; hex 800003ee; asc ;; 1: len 4; hex 80000006; asc ;;
*** (2) WAITING FOR THIS LOCK TO BE GRANTED:RECORD LOCKS space id 224 page no 4 n bits 80 index uk_stu_id of table `testdb`.`test_tb` trx id 46914 lock_mode X locks rec but not gap waitingRecord lock, heap no 6 PHYSICAL RECORD: n_fields 2; compact format; info bits 0 0: len 4; hex 800003ed; asc ;; 1: len 4; hex 80000005; asc ;;#上面这部分是事务二正在等待的锁,从信息上看,等待的是同一个表,同一个索引,同一个page上的record lock X锁,但是heap no位置不同,即不同的行上的锁
*** WE ROLL BACK TRANSACTION (2) #表示事务2被回滚
评论