mysql死锁怎么解决?Lock wait timeout exceeded; try restarting transaction

问题出现:
最近在kettle传数据的时候,发现在往mysql库中传数据时出现了Lock wait timeout exceeded的问题,接口响应的时间超长,耗时五十秒左右才返回错误提示,后台日志中出现Lock wait timeout exceeded; try restarting transaction的错误。

问题场景:

1、在同一事务内先后对同一条数据进行插入和更新操作;

2、多台服务器操作同一数据库;

3、瞬时出现高并发现象;

问题原因:

1、在高并发的情况下,Spring事物造成数据库死锁,后续操作超时抛出异常。

2、Mysql数据库采用InnoDB模式,默认参数:innodb_lock_wait_timeout设置锁等待的时间是50s,一旦数据库锁超过这个时间就会报错。
  解决方法:
  用到的查询语句:

SELECT * FROM information_schema.INNODB_TRX
SELECT * FROM information_schema.INNODB_LOCKs
SELECT * FROM information_schema.innodb_trx

SHOW OPEN TABLES WHERE In_use > 0
SHOW PROCESSLIST

1、查看数据库当前的进程,看一下有无正在执行的慢SQL记录线程。

mysql> show  processlist;

2、查看当前的事务

当前运行的所有事务

mysql> SELECT * FROM information_schema.INNODB_TRX;

当前出现的锁:

mysql> SELECT * FROM information_schema.INNODB_TRX;

锁等待的对应关系

mysql> SELECT * FROM information_schema.INNODB_LOCK_waits;

解释:看事务表INNODB_TRX,里面是否有正在锁定的事务线程,看看ID是否在show processlist里面的sleep线程中,如果是,就证明这个sleep的线程事务一直没有commit或者rollback而是卡住了,我们需要手动kill掉。

搜索的结果是在事务表发现了很多任务,这时候最好都kill掉。

我这个查询这个三个表,都没有数据。就把所有进程中sleep的进程全给删了,发现就可以了。我百度也没找到我这种“偏方”,但是有效,不妨试一试。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值