Lock wait timeout exceeded; try restarting transaction

具体报错 

### Cause: com.mysql.cj.jdbc.exceptions.MySQLTransactionRollbackException: Lock wait timeout exceeded; try restarting transaction
; Lock wait timeout exceeded; try restarting transaction; nested exception is com.mysql.cj.jdbc.exceptions.MySQLTransactionRollbackException: Lock wait timeout exceeded; try restarting transaction

错误 com.mysql.cj.jdbc.exceptions.MySQLTransactionRollbackException: Lock wait timeout exceeded; try restarting transaction 通常是由于数据库中的锁超时引起的。这意味着在某个事务等待某个资源上的锁时超时了,没有得到该资源的锁,从而引发了这个异

怎么立即处理掉这个问题 ?

要解决 MySQL 中的锁等待超时问题,可以采取以下措施来释放或避免锁

1. 查看和终止锁持有者

首先,找出持有锁的会话,并终止它。这可以通过以下步骤完成:

查找锁持有者

使用以下查询来查看当前锁的情况:

SELECT 
    r.trx_id AS waiting_trx_id,
    r.trx_mysql_thread_id AS waiting_thread,
    r.trx_query AS waiting_query,
    b.trx_id AS blocking_trx_id,
    b.trx_mysql_thread_id AS blocking_thread,
    b.trx_query AS blocking_query
FROM
    information_schema.innodb_lock_waits w
        INNER JOIN
    information_schema.innodb_trx b ON b.trx_id = w.blocking_trx_id
        INNER JOIN
    information_schema.innodb_trx r ON r.trx_id = w.requesting_trx_id;

这个查询将返回正在等待锁的事务以及正在阻塞的事务。

终止锁持有者

找出阻塞事务的 thread_id 后,可以使用以下命令终止该会话:

KILL <blocking_thread_id>;

到此 你的阻塞事务就被处理掉了

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值