博客
关于我
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 内连接、自然连接、外连接的区别
查看>>
mysql 写入慢优化
查看>>
mysql 分组统计SQL语句
查看>>
Mysql 分页
查看>>
Mysql 分页语句 Limit原理
查看>>
MySql 创建函数 Error Code : 1418
查看>>
MySQL 创建新用户及授予权限的完整流程
查看>>
mysql 创建表,不能包含关键字values 以及 表id自增问题
查看>>
mysql 删除日志文件详解
查看>>
mysql 判断表字段是否存在,然后修改
查看>>
MySQL 到底能不能放到 Docker 里跑?
查看>>
mysql 前缀索引 命令_11 | Mysql怎么给字符串字段加索引?
查看>>
MySQL 加锁处理分析
查看>>
mysql 协议的退出命令包及解析
查看>>
mysql 参数 innodb_flush_log_at_trx_commit
查看>>
mysql 取表中分组之后最新一条数据 分组最新数据 分组取最新数据 分组数据 获取每个分类的最新数据
查看>>
MySQL 命令和内置函数
查看>>
mysql 四种存储引擎
查看>>
MySQL 在并发场景下的问题及解决思路
查看>>