设置expire_logs_days自动过期清理binlog

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

  1. mysql> show variables like 'expire_logs_days'
  2. mysql> set global expire_logs_days=7;
  3. 设置之后不会立即清除,触发条件是:
    binlog大小超过max_binlog_size  (默认max_binlog_size=1G)
    手动执行flush logs
    重新启动时(MySQL将会new一个新文件用于记录binlog)
  4. 我们执行flush logs;

    mysql> flush logs;

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

    将bin.000055之前的binlog清掉:

    1. mysql>purge binary logs to 'bin.000055';
    2. 将指定时间之前的binlog清掉:
       mysql>purge binary logs before '2017-05-01 13:09:51';
原文地址:https://www.cnblogs.com/vzhangxk/p/15422999.html