具体报错 

### 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>;

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

Logo

一站式 AI 云服务平台

更多推荐