博客
关于我
mysqldump数据库备份无法进行操作只能查询 --single-transaction
阅读量:791 次
发布时间:2023-02-11

本文共 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/

你可能感兴趣的文章
MYSQL sql语句针对数据记录时间范围查询的效率对比
查看>>
mysql sum 没返回,如果没有找到任何值,我如何在MySQL中获得SUM函数以返回'0'?
查看>>
mysql sysbench测试安装及命令
查看>>
mysql Timestamp时间隔了8小时
查看>>
Mysql tinyint(1)与tinyint(4)的区别
查看>>
MySQL Troubleshoting:Waiting on query cache mutex
查看>>
mysql union orderby 无效
查看>>
mysql v$session_Oracle 进程查看v$session
查看>>
mysql where中如何判断不为空
查看>>
MySQL Workbench 使用手册:从入门到精通
查看>>
MySQL Workbench 数据库建模详解:从设计到实践
查看>>
MySQL Workbench 数据建模全解析:从基础到实践
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
MySQL —— 视图
查看>>