本文共 471 字,大约阅读时间需要 1 分钟。
某在线项目客户反馈登录异常,提示链接超时。项目采用前后端分离架构,前端等待后端返回超过10分钟后提示超时。经过初步排查,发现线程堵塞问题。
使用jstack工具分析线程卡顿情况,发现问题出在数据库查询模块。具体来看,修改account
表中当前登录人IP的操作经常卡住,尽管查询登录名是否存在无问题。进一步检查发现,数据库查询在执行select * from information_schema.processlist where info is not null;
时,所有进程的状态均为"Waiting for table metadata lock"。这表明某个地方占用了表锁,导致SQL无法正常执行。
进一步排查发现,执行LOCK TABLES account READ
命令时,发现是本地备份脚本引发的线程堵塞。备份脚本在凌晨8点执行完毕,与客户反馈的服务重启时间一致,初步判断为备份过程延迟导致的问题。
针对此问题,调整了mysqldump备份设置,确保备份过程不影响正常业务操作。最终问题得以解决。
转载地址:http://nibfk.baihongyu.com/