mysql死锁

作者: sunpy | 来源:发表于2022-09-04 16:31 被阅读0次

什么场景会出现死锁


两个或者两个以上的事务在执行过程中,出现了因为争夺资源造成的一种互相等待情况。

共享锁死锁的情况

session1 session2
set autocommit =0; set autocommit =0;
select * from edu_user lock in share mode; select * from edu_user lock in share mode;
阻塞:update edu_user set password="456789" where username = "王五";
报错:update edu_user set password="012345" where username = "王五";
自动结束当前事务:1213 - Deadlock found when trying to get lock; try restarting transaction
commit;

说明:
session1和session2都开启事务后,都获取了同一把共享锁,但是session1写操作需要对方阻塞,等待。session2写操作同样需要对方阻塞,等待。两个都饥饿获取不到锁,产生了死锁。

排他锁死锁的情况


session1 session2
set autocommit =0;
select * from edu_user where id = 1 for update; set autocommit =0;
select * from edu_user where id = 2 for update;
阻塞等待:select * from edu_user where id = 2 for update;
select * from edu_user where id = 1 for update;
1213 - Deadlock found when trying to get lock; try restarting transaction

说明:
session1和session都手动提交事务时,session1获取了id为1的记录的排他锁,session2获取了id为2的记录的排他锁。那么session1再想获取id为2的排他锁只能等待session2释放锁,session2再想获取id为1的排他锁只能等待session1释放锁。双方都等待对方释放锁,那么就互相都饥饿,获取不到锁,产生了死锁。

解决方法1,手动整个事务回滚


mysql> rollback;
Query OK, 0 rows affected (0.00 sec)

解决方法2,设置超时回滚


# 说明:事务等待行锁定的时间,默认值为50秒。发生锁定等待超时,将回滚当前语句。
innodb_lock_wait_timeout
#说明:InnoDB默认情况下只会回滚事务超时的最后一个语句。指定这个参数将回滚整个事务。
innodb_rollback_on_timeout

相关文章

  • 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/tfdmnrtx.html