MySQL修改binlog保存的天数

2022-11-21 21:10:40 浏览数 (2)

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

代码语言:javascript复制
mysql> show variables like 'expire_logs_days';
 ------------------ ------- 
| Variable_name | Value |
 ------------------ ------- 
| expire_logs_days | 90 |
 ------------------ ------- 
1 row in set (0.00 sec)
代码语言:javascript复制
mysql> set global expire_logs_days=7;
Query OK, 0 rows affected (0.00 sec)

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

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

我们执行flush logs;

代码语言:javascript复制
mysql> flush logs;
Query OK, 0 rows affected, 64 warnings (0.16 sec

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

将bin.000055之前的binlog清掉:

代码语言:javascript复制
mysql>purge binary logs to 'bin.000055';

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

代码语言:javascript复制
mysql>purge binary logs before '2017-05-01 13:09:51';

0 人点赞