在一个复杂的业务功能中,可能会出现锁竞争失败的情况,就会导致以下报错MySQLTransactionRollbackException: Lock wait timeout exceeded;此时可以查询数据库锁表情况,当前事务信息等等。
innodb_locks 查询锁的相关信息,这里记录了事务获取不到某个锁和阻塞了其他事务的数据;一般关注较多的是锁的类型,看是行锁还是表锁;有时候还要关注下锁的索引,我们这个问题原因就是因为某个表有多个单列索引,但是在操作表的时候走了A索引,而不是B索引,因此导致锁表了,最终是删掉单列索引,创建联合索引解决;
innodb_lock_waits查询阻塞其他事务的锁的关联信息;
innodb_trx查询当前的事务信息,着重看事务状态trx_state是lock wait的,如果要杀掉卡住的进程,则执行 kill trx_mysql_thread_id即可;