博客
关于我
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 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
MySQL 导出数据
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
MySQL 常见的 9 种优化方法
查看>>
MySQL 常见的开放性问题
查看>>
Mysql 常见错误
查看>>
mysql 常见问题
查看>>