|
|
|
|
公众号矩阵

记一次生产线MySQL库Binlog日志占满磁盘的故障处理

今天早上监控平台邮件通知生产某业务系统的MySQL数据库存储空间达到了90%,赶紧爬起来远程连上数据库主机,发现Master双主MySQL数据库10.5.11.105、和10.5.11.106数据目录/var/lib/mysql空间使用率达到了97%和96%。

作者:阿龙说运维来源:今日头条|2021-01-12 07:57

 一、故障描述

今天早上监控平台邮件通知生产某业务系统的MySQL数据库存储空间达到了90%,赶紧爬起来远程连上数据库主机,发现Master双主MySQL数据库10.5.11.105、和10.5.11.106数据目录/var/lib/mysql空间使用率达到了97%和96%。

二、问题分析过程

首先查询确认数据库主从关系

登录10.5.11.105和10.5.11.106数据库,执行语句:show slave status\G; 查看。

说明10.5.11.106数据库master-bin.000779之前的binlog是可以清理的。

执行语句:show slave hosts \G 查看server id。

说明Server_id:33333是10.5.11.105的从库。

执行语句:show variables like ‘server_id’可以确认。

三、查询binlog自动清理是否开启

执行如下语句show variables like 'expire_logs_days';

查看参数发现binlog自动清理功能没有开启。

四、查看具体的binlog文件

执行语句:show binary logs;

可以看到有大量的binlog文件。

记一次生产线MySQL库binlog日志占满磁盘的故障处理

五、查看binlog具体的存放路径

执行语句:show variables like '%log_bin_basename%'; 查看。

六、问题的根本原因

经过排查,我们发现问题的根本原因在于没有开启binlog自动清理功能,导致有大量的binlog进行积压所致。

七、处理问题

清理binlog文件。通过确认主从应用最新的binlog来清理binlog,使用如下命令,清理的时候可以多留几个binlog,注意不要手动rm binlog文件。

1、Purge binary logs to_’binlog文件名’;来清理binlog日志。

2、开启自动清理binlog日志功能(主从库都需执行)

执行语句:

set global expire_logs_days=10;

并在/etc/my.cnf的配置文件中增加如下配置:

expire_logs_days=10

注意:binlog日志过期时间可根据自己公司的要求自定义,我这里设置的是10天!

【编辑推荐】

  1. 一文教你探测虚拟环境是物理机、虚拟机还是容器?
  2. 比较9款代码质量工具,看看哪款更好用
  3. 推荐十个好用的程序员摸鱼网站,现在就给我玩起来!
  4. 2021年网络安全趋势:更高的预算,重点终端和云安全
  5. 为什么码农不应该在面试中同意进行编程测试
【责任编辑:姜华 TEL:(010)68476606】

点赞 0
分享:
大家都在看
猜你喜欢

订阅专栏+更多

数据湖与数据仓库的分析实践攻略

数据湖与数据仓库的分析实践攻略

助力现代化数据管理:数据湖与数据仓库的分析实践攻略
共3章 | 创世达人

1人订阅学习

云原生架构实践

云原生架构实践

新技术引领移动互联网进入急速赛道
共3章 | KaliArch

30人订阅学习

数据中心和VPDN网络建设案例

数据中心和VPDN网络建设案例

漫画+案例
共20章 | 捷哥CCIE

209人订阅学习

订阅51CTO邮刊

点击这里查看样刊

订阅51CTO邮刊

51CTO服务号

51CTO官微