系统内单个业务模块查询超时-表锁

问题描述:查询数据,系统内别的功能正常,单个功能查询超时
问题排查思路:
1、重启系统服务后,依然如此。撇清服务运行导致的问题;
2、重启服务时:停止线程大多信息是druid的信息,猜测数据库连接问题;
3、排查数据库连接,正常,连接数不多
4、排查数据库表锁问题,发现单个功能业务主表死锁;
查询语句:
SHOW ENGINE INNODB STATUS; 查询死锁信息
SELECT * FROM performance_schema.data_locks WHERE lock_status = ‘WAITING’; 查询锁等待
问题解决:
1、使用FLUSH TABLES WITH READ LOCK命令来手动刷新并解锁表。这个命令可以释放表级锁。
2、FLUSH TABLES;
3、简单粗暴,重启mysql服务(生产环境不建议)
4、杀死锁定会话进程
5、查询事务,终止事务
其余查询命令:
SHOW ENGINE INNODB STATUS;MySQL中是否存在事务正在进行
SELECT * FROM information_schema.innodb_trx;当前正在执行的事务

show processlist 查看进程
kill id 杀死进程

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值