具体报错
### 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>;
到此 你的阻塞事务就被处理掉了