mysql死锁排查_mysql 死锁问题排查

复制代码
应用访问Mysql数据库的时候,如果业务逻辑写的不严谨,不规范,就会发生死锁,如果此业务逻辑调用并发高,则业务日志经常会有死锁的错误日志产生。应用发生死锁,于是dba就去排查,看数据库的错误日志,就会发现,没有任何关于死锁的日志告警,这是因为默认配置情况下,数据库是不打印任何死锁的日志信息。

 那如何去排查应用的死锁问题呢,下面给大家详细介绍。先看看关于死锁信息打印的参数,默认是关闭

mysql> show variables like 'innodb\_print\_all\_deadlocks';
+----------------------------+-------+
| Variable_name              | Value |
+----------------------------+-------+
| innodb_print_all_deadlocks | OFF   |
+----------------------------+-------+
1 row in set (0.01 sec)

想要在发生死锁的情况打印相关信息,需要开启这个参数

复制代码
mysql> set global innodb_print_all_deadlocks=on;
Query OK, 0 rows affected (0.00 sec)
mysql> show variables like 'innodb\_print\_all\_deadlocks';
+----------------------------+-------+
| Variable_name              | Value |
+----------------------------+-------+
| innodb_print_all_deadlocks | ON    |
+----------------------------+-------+
1 row in set (0.01 sec)

开启之后,下面模拟一个死锁的场景
开启会话1,执行如下语句

复制代码
mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> update t_test10 set name='test33' where id='1';
Query OK, 0 rows affected (0.00 sec)
Rows matched: 1  Changed: 0  Warnings: 0

mysql> update t_test10 set name='testkii' where id='4';
Query OK, 0 rows affected (5.38 sec)
Rows matched: 1  Changed: 0  Warnings: 0

开启会话2,执行如下语句

复制代码
mysql> begin;
Query OK, 0 rows affected (0.00 sec)

mysql> update t_test10 set name='testkii' where id='4';
Query OK, 0 rows affected (0.00 sec)
Rows matched: 1  Changed: 0  Warnings: 0

mysql> update t_test10 set name='test33' where id='1';
ERROR 1213 (40001): Deadlock found when trying to get lock; try restarting transaction

在会话2里,可以很明显的看到,mysql检测到Deadlock,并回滚了会话2的sql,让会话的事物能继续进行。那mysql怎么选择回滚那个会话呢,主要从回滚代价上去考虑的,谁的锁持有的少,则回滚对应的会话事物。下面看看数据库的死锁详细信息看看

在数据库告警日志可以找死锁发生时,对应的sql语句和应用访问用户,应用访问IP,有了这些只会,再去找开发,看对应的代码逻辑,就能很容易的定位到问题,并解决。

相关推荐
xiaokangzhe几秒前
MySQL主从复制读写分离笔记
笔记·mysql·adb
羊小蜜.3 分钟前
Mysql 01:基础查询(SELECT)全解——从单表到多字段的完整语法
数据库·mysql·查询
猿小喵16 分钟前
记录一次从库并行回放出现死锁的问题
数据库·mysql·tdsql
hnlgzb18 分钟前
目前编写安卓app的话有哪几种设计模式?
android·设计模式·kotlin·android jetpack·compose
随风,奔跑23 分钟前
Redis
数据库·redis·缓存
IvorySQL24 分钟前
2MB 的 PostgreSQL work_mem,如何吃掉 2TB 内存?
数据库·postgresql·开源
桑榆肖物26 分钟前
有字幕,没配音?用浏览器自带语音能力,让网页视频直接“开口说话”
数据库·edge·音视频·tts
studyForMokey1 小时前
【Android面试】Fragment生命周期专题
android·microsoft·面试
熬夜的咕噜猫1 小时前
MySQL主从复制与读写分离
网络·数据库·mysql
道清茗1 小时前
【MySQL知识点问答题】 备份技术、Invisible Indexes 和直方图的应用
数据库·mysql