美文网首页
mysql死锁

mysql死锁

作者: coderljx | 来源:发表于2022-11-02 18:00 被阅读0次

死锁是什么

死锁是并发系统中常见的问题,同样也会出现在数据库MySQL的并发读写请求场景中。当两个及以上的事务,双方都在等待对方释放已经持有的锁或因为加锁顺序不一致造成循环等待锁资源,就会出现“死锁”。常见的报错信息为 Deadlock found when trying to get lock...。

image.png

为什么会有死锁

从死锁的定义来看,MySQL 出现死锁的几个要素为:

两个或者两个以上事务

每个事务都已经持有锁并且申请新的锁

锁资源同时只能被同一个事务持有或者不兼容

事务之间因为持有锁和申请锁导致彼此循环等待

如何尽可能避免避免

合理的设计索引,区分度高的列放到组合索引前面,使业务 SQL 尽可能通过索引定位更少的行,减少锁竞争。

调整业务逻辑 SQL 执行顺序, 避免 update/delete 长时间持有锁的 SQL 在事务前面。

避免大事务,尽量将大事务拆成多个小事务来处理,小事务发生锁冲突的几率也更小。

以固定的顺序访问表和行。比如两个更新数据的事务,事务 A 更新数据的顺序为 1,2;事务 B 更新数据的顺序为 2,1。这样更可能会造成死锁。

在并发比较高的系统中,不要显式加锁,特别是是在事务里显式加锁。如 select … for update 语句,如果是在事务里(运行了 start transaction 或设置了autocommit 等于0),那么就会锁定所查找到的记录。

尽量按主键/索引去查找记录,范围查找增加了锁冲突的可能性,也不要利用数据库做一些额外额度计算工作。比如有的程序会用到 “select … where … order by rand();”这样的语句,由于类似这样的语句用不到索引,因此将导致整个表的数据都被锁住。

优化 SQL 和表设计,减少同时占用太多资源的情况。比如说,减少连接的表,将复杂 SQL 分解为多个简单的 SQL。

参考
https://blog.csdn.net/sufu1065/article/details/120329354

相关文章

  • MySQL笔记-锁、事务与并发控制

    MySQL服务器逻辑架构 MySQL并发控制 MySQL死锁问题 MySQL中的事务

  • mysql死锁-非主键索引更新引起的死锁

    [mysql死锁-非主键索引更新引起的死锁] 背景:最近线上经常抛出mysql的一个Deadlock,细细查来,长...

  • 一则由于索引导致的MySQL死锁分析

    涉及死锁的 authorized_user 表的 DDL 死锁日志 根据 MySQL 日志分析出来的涉及死锁的 S...

  • MySQL死锁案例分析一(先delete,再insert,导致死

    一、死锁案例 MySQL版本:Percona MySQL Server 5.7.19隔离级别:可重复读(RR)业务...

  • mysql简单排查&终止死锁线程 2022-03-29

    mysql简单排查&终止死锁线程 INFORMATION_SCHEMA MySQL把INFORMATION_SCH...

  • MySQL -- 死锁

    死锁: 死锁是指两个或者多个事务在同一资源上相互占用,并请求锁定对方占用的资源,从而导致恶性循环的现象,当多个事务...

  • MySQL死锁

    死锁大家应该不会陌生,互相占用对方资源,互相等待释放,从而产生恶性循环,在数据库中当多个事务试图以不同的顺序来锁定...

  • mysql 死锁

    简介 死锁是两个或者多个竞争的操作在等待其他操作完成.死锁发生有 4 个条件:1: 互斥: 在一个时间点只有一个进...

  • MySQL死锁

    一、形成原因:一般是事务相互等待对方释放资源,最后形成环路造成的 二、场景模拟一: id(PRIMARY )nam...

  • MySql 死锁

    死锁是指两个或多个事务在同一资源上相互占用,并请求锁定对方占用的资源,从而导致恶性循环的现象。当多个事务视图以不同...

网友评论

      本文标题:mysql死锁

      本文链接:https://www.haomeiwen.com/subject/vluetdtx.html