mysql 死锁

2020-07-08  本文已影响0人  wwq2020

简介

死锁是两个或者多个竞争的操作在等待其他操作完成.
死锁发生有 4 个条件:
1: 互斥: 在一个时间点只有一个进程可以使用这个资源
2: 持有而且等待资源: 一个进程持有了至少一个资源并且在请求被其他进程持有的资源
3: 没有抢占: 资源只能被他持有的人释放
4: 循环等待: 每个进程必须等待正被其他进程持有的资源释放

记录死锁日志

使用 pt-deadlock-logger

创建表
pt-deadlock-logger --create-dest-table --dest D=test,t=deadlocks u=root,h=127.0.0.1
启动记录死锁日志
pt-deadlock-logger --daemonize --run-time=3000 --dest D=test,t=deadlocks u=root,h=127.0.0.1

设置 innodb_print_all_deadlocks(mysql5.6 以上)

减少死锁

1 使用避免使用锁设计策略
2 优化查询(查询更少的行,加更少的锁)
3 禁用 deadlock 检测(mysql8),设置较小的 innodb_lock_wait_timeout(默认 50)
4 大事务改为小事务
5 添加索引

上一篇 下一篇

猜你喜欢

热点阅读