mysql执行更新语句多线程执行锁表解决

在一个复杂的业务功能中,可能会出现锁竞争失败的情况,就会导致以下报错MySQLTransactionRollbackException: Lock wait timeout exceeded;此时可以查询数据库锁表情况,当前事务信息等等。

innodb_locks 查询锁的相关信息,这里记录了事务获取不到某个锁和阻塞了其他事务的数据;一般关注较多的是锁的类型,看是行锁还是表锁;有时候还要关注下锁的索引,我们这个问题原因就是因为某个表有多个单列索引,但是在操作表的时候走了A索引,而不是B索引,因此导致锁表了,最终是删掉单列索引,创建联合索引解决;

innodb_lock_waits查询阻塞其他事务的锁的关联信息;

innodb_trx查询当前的事务信息,着重看事务状态trx_state是lock wait的,如果要杀掉卡住的进程,则执行 kill trx_mysql_thread_id即可;

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值