博客
关于我
mysqldump数据库备份无法进行操作只能查询 --single-transaction
阅读量:792 次
发布时间: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 Binlog 日志监听与 Spring 集成实战
查看>>
multi-angle cosine and sines
查看>>
Mysql Can't connect to MySQL server
查看>>
mysql case when 乱码_Mysql CASE WHEN 用法
查看>>
Multicast1
查看>>
MySQL Cluster 7.0.36 发布
查看>>
Multimodal Unsupervised Image-to-Image Translation多通道无监督图像翻译
查看>>
multipart/form-data与application/octet-stream的区别、application/x-www-form-urlencoded
查看>>
mysql cmake 报错,MySQL云服务器应用及cmake报错解决办法
查看>>
Multiple websites on single instance of IIS
查看>>
mysql CONCAT()函数拼接有NULL
查看>>
multiprocessing.Manager 嵌套共享对象不适用于队列
查看>>
multiprocessing.pool.map 和带有两个参数的函数
查看>>
MYSQL CONCAT函数
查看>>
multiprocessing.Pool:map_async 和 imap 有什么区别?
查看>>
MySQL Connector/Net 句柄泄露
查看>>
multiprocessor(中)
查看>>
mysql CPU使用率过高的一次处理经历
查看>>
Multisim中555定时器使用技巧
查看>>
MySQL CRUD 数据表基础操作实战
查看>>