问题描述:查询数据,系统内别的功能正常,单个功能查询超时
问题排查思路:
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 杀死进程