设置expire_logs_days自动过期清理binlog

生产上有一个比较小的系统,发现mysql占用空间较大,经排查发现是binlog比较多引起的

查看binlog过期时间,设置的时间为90天,这个值默认是0天,也就是说不自动清理,可以根据生产情况修改,本例修改为7天

  1. mysql> show variables like 'expire_logs_days';
  2. +------------------+-------+
  3. | Variable_name | Value |
  4. +------------------+-------+
  5. | expire_logs_days | 90 |
  6. +------------------+-------+
  7. 1 row in set (0.00 sec)

 

  1. mysql> set global expire_logs_days=7;
  2. Query OK, 0 rows affected (0.00 sec)

设置之后不会立即清除,触发条件是:

 

binlog大小超过max_binlog_size
手动执行flush logs
重新启动时(MySQL将会new一个新文件用于记录binlog)

我们执行flush logs;

  1. mysql> flush logs;
  2. Query OK, 0 rows affected, 64 warnings (0.16 sec

如果binlog非常多,不要轻易设置改参数,有可能导致io争用,这时候可以使用purge命令予以清除:

 

将bin.000055之前的binlog清掉:

  1. mysql>purge binary logs to 'bin.000055';

将指定时间之前的binlog清掉:

 
    1. mysql>purge binary logs before '2017-05-01 13:09:51';
posted @   鸾舞春秋  阅读(407)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
历史上的今天:
2020-03-23 基于SAR对Linux资源的监控shell脚本
2020-03-23 sar查看网卡流量
点击右上角即可分享
微信分享提示