MySQL—死锁

什么是死锁?

好比是两个事务都在等待对方释放锁,之后进行下一步操作,但是最后双方都没有释放资源,所以导致一直处于等待的状态。

但是服务器不会让死锁的状态一直持续,会关闭其中一个影响较小的事务(右边的事务关闭),

参考链接:死锁面试题(什么是死锁,产生死锁的原因及必要条件)-CSDN博客

怎么查看有没有发生死锁呢?

查询是否锁表

复制代码
show OPEN TABLES where In_use > 0;

查看当前的事务

复制代码
SELECT * FROM INFORMATION_SCHEMA.INNODB_TRX;

查看当前锁定的事务

复制代码
SELECT * FROM INFORMATION_SCHEMA.INNODB_LOCKS;

查看当前等锁的事务

复制代码
ELECT * FROM INFORMATION_SCHEMA.INNODB_LOCK_WAITS;

减少死锁:

  1. 使用事务,不使用 lock tables 。
  2. 保证没有长事务。
  3. 尽量基于primary或unique key更新数据
  4. 操作完之后立即提交事务,特别是在交互式命令行中。
  5. 如果在用 (SELECT ... FOR UPDATE or SELECT ... LOCK IN SHARE MODE),尝试降低隔离级别。注意:select ... for update (表级锁)、select ... lock in share mode(行级锁)
  6. 修改多个表或者多个行的时候,将修改的顺序保持一致。
  7. 创建索引,可以使创建的锁更少。
  8. 最好不要用 (SELECT ... FOR UPDATE or SELECT ... LOCK IN SHARE MODE)。
  9. 如果上述都无法解决问题,那么尝试使用 lock tables t1, t2, t3 锁多张表
  10. 使用乐观锁和减少锁的粒度,保证一致的锁定顺序,合计设计索引,避免大事务。
  11. 等待超时时,回滚事务或者结束进程。

MySQL死锁的解决方案

彻底搞懂MySQL死锁_mysql deadlock-CSDN博客

面试必问!MySQL死锁是什么,如何解决?史上最全!-CSDN博客

彻底搞懂MySQL死锁_mysql deadlock-CSDN博客

mysql查看死锁和解除锁_查mysql死锁-CSDN博客

相关推荐
m0_609160497 分钟前
Go语言Beego框架如何用_Go语言Beego框架入门教程【高效】
jvm·数据库·python
未若君雅裁2 小时前
MySQL-MVCC核心原理-版本链ReadView与可见性判断
数据库·mysql
KaMeidebaby6 小时前
卡梅德生物技术快报|骆驼纳米抗体:从原核表达、高通量测序到分子对接全流程实现
前端·数据库·其他·百度·新浪微博
2301_783848659 小时前
优化文本分类中堆叠模型的网格搜索性能:避免训练卡顿的实战指南
jvm·数据库·python
拾贰_C9 小时前
【Ubuntu | 公共工作站 | mysql 】 MySQL残留物残留数据
linux·mysql·ubuntu
TE-茶叶蛋9 小时前
DBeaver 的Explain 执行计划,分析sql的性能
数据库·sql
CLX050510 小时前
如何安装Oracle 12c Cloud Control_OMS服务端组件与Agent部署
jvm·数据库·python
m0_6174939410 小时前
PySide6 网络请求深度实测:从基础 API 调用到数据解析实战指南
数据库
知识汲取者10 小时前
每日一篇高频面试题系列之【MySQL 锁】
数据库·mysql
老纪10 小时前
SQL中如何查找特定的空值行:WHERE IS NULL深度解析
jvm·数据库·python