mysql dead_MySql数据库死锁deadlock

今天在项目性能测试中遇到个Mysql的DeadLock的问题。 后来根据数据库日子查找原因,大概模拟一下发生的情形。 数据库用的innoDB。 InnoDB 行锁是通过给索引上的索引项加锁来实现的, InnoDB 这种行锁实现特点意味着:只有通过索引条件检索数据, InnoDB 才使

今天在项目性能测试中遇到个Mysql的DeadLock的问题。

后来根据数据库日子查找原因,大概模拟一下发生的情形。

数据库用的innoDB。

InnoDB行锁是通过给索引上的索引项加锁来实现的,InnoDB这种行锁实现特点意味着:只有通过索引条件检索数据,InnoDB才使用行级锁,否则,InnoDB将使用表锁!

下面例子中id是主键,操作都走索引,锁都是row lock。

table中数据

test.jsp?url=http%3A%2F%2Fimg.my.csdn.net%2Fuploads%2F201210%2F25%2F1351171924_2293.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fitleochen%2Farticle%2Fdetails%2F8112738

用2个线程做如下操作,将发生死锁现象,且1个线程执行成功,另一个线程失败。

test.jsp?url=http%3A%2F%2Fimg.my.csdn.net%2Fuploads%2F201210%2F25%2F1351176382_7847.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fitleochen%2Farticle%2Fdetails%2F8112738

最终结果:第一条数据被改变,第3条数据不变。

test.jsp?url=http%3A%2F%2Fimg.my.csdn.net%2Fuploads%2F201210%2F25%2F1351172518_8485.jpg&refer=http%3A%2F%2Fblog.csdn.net%2Fitleochen%2Farticle%2Fdetails%2F8112738

MySql的InnoDB,\加了事务的select语句索引的记录,会加S锁, insert,delete,update会加X锁。

设定左边为线程1,右边为线程2

线程1在id=1的一行记录上加了S锁, 当线程2要update操作这行记录时,要在记录上加X锁, 此时需要等待线程1释放id=1记录上的S锁。

线程2在id=3的一行记录上加了S锁, 当线程1要update操作这行记录时,要在记录上加X锁, 此时需要等待线程2释放id=3记录上的S锁。

彼此互相等待,然后就死锁了。

Mysql释放死锁的机制,看锁定的记录数,一般会允许锁定记录多的事务执行通过, 而锁定记录少的事物回滚。范围同等时应该是按X锁请求的先后了。

补充说明: InnoDB 如果where后面的条件字段没有索引,则加锁时是会锁表。走索引只会锁查询或操作的记录。InnoDB事务中的查询条件需要小心了

互斥

S

X

S

X

先写这么多。

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值