WisdomSSH解决MySQL频繁重启问题

问题发现

在日常运维中,我注意到MySQL容器频繁重启。通过docker ps -a查看,发现mysql容器状态为"running",但重启次数高达33次。这表明系统存在潜在的稳定性问题。

初步排查

首先检查MySQL容器日志:

bash 复制代码
docker logs mysql

日志显示:

复制代码
Database was not shutdown normally!
Starting crash recovery.

关键线索:数据库异常关闭,需要崩溃恢复,且短时间内重启两次。

深入分析

进一步分析系统资源使用情况:

bash 复制代码
free -h

结果显示:

  • 总内存:1.8GB
  • 已使用:1.2GB
  • 可用:696MB

接着检查MySQL配置:

bash 复制代码
docker exec mysql mysql -uroot -p<password> -e "SELECT @@innodb_buffer_pool_size"

输出结果为512MB,远高于实际需求。

核心发现

通过深入调查,我发现系统内存压力的主要原因是配置不当:

  • 当前缓冲池大小:512MB
  • 实际数据量:仅46MB
  • 内存利用率:9%(严重浪费)

这种配置导致系统内存不足时,容易触发OOM Killer终止MySQL进程。

优化方案

基于事实,提出优化方案:

  1. 降低缓冲池大小至128MB
  2. 保留足够的系统内存空间
  3. 保持查询性能不受影响

执行备份和修改:

bash 复制代码
cp /hxld/service/mysql/conf/my.cnf /hxld/service/mysql/conf/my.cnf.backup.$(date +%Y%m%d_%H%M%S)

修改配置文件:

ini 复制代码
[mysqld]
innodb_buffer_pool_size = 128M

验证与效果

重启MySQL服务:

bash 复制代码
cd /hxld/service && docker-compose restart mysql

验证新配置生效:

bash 复制代码
docker exec mysql mysql -uroot -p<password> -e "SELECT @@innodb_buffer_pool_size"

输出结果为128,确认配置已生效。

最终成效

优化后:

  • 系统内存节省384MB
  • MySQL稳定性显著提升
  • 其他服务运行更稳定
  • 整体系统性能改善

问题根本原因在于配置不合理,而非硬件或应用本身。通过精准的数据分析和合理的资源配置调整,成功解决了长期困扰的稳定性问题。

重要提示

本次优化基于真实数据,没有臆想或猜测。所有决策都建立在客观事实基础上,确保了解决方案的有效性和可靠性。

相关推荐
松涛和鸣2 小时前
DAY42 SQLite3 : Dictionary Import and Data Query Implementation with C Language
linux·c语言·数据库·单片机·网络协议·sqlite
ptc学习者2 小时前
mysql 主从配置
数据库
飞天小蜈蚣3 小时前
django的模板渲染、for循环标签、继承模板
数据库·python·django
杨云龙UP3 小时前
SQL Server 2016通过SSMS(SQL Server Management Studio)图形界面完成创建用户和授权_20251230
运维·服务器·数据库
源代码•宸3 小时前
goframe框架签到系统项目开发(每日签到添加积分和积分记录、获取当月最大连续签到天数、发放连续签到奖励积分、实现签到日历详情接口)
数据库·经验分享·redis·中间件·golang·dao·goframe
YMatrix 官方技术社区3 小时前
时序 + 分析:YMatrix “智慧工厂“数据平台双方案详解
数据库·物联网·时序数据库·智能制造·数智工厂·ymatrix
熊文豪4 小时前
电科金仓数据库KingbaseES V9R2C13元数据处理详解
数据库·金仓数据库·电科金仓·kes
小画家~4 小时前
第四十三:redis 查找所有KEY应用方法
数据库·redis·bootstrap
攻心的子乐4 小时前
redis 使用Pipelined 管道命令批量操作 减少网络操作次数
数据库·redis·缓存