MySQL binlog日志清理方案

# 登录mysql数据库
mysql -u root –p

# 查看binlog是否开启,log_bin的状态为ON,表明binlog日志开启
show variables like 'log_%';

# 查看binlog日志文件大小,单位bytes
show binary logs;

# 显示binlog的过期时间,mysql5版本参数为expire_logs_days(默认值为0,标识从不删除),mysql8版本参数为binlog_expire_logs_seconds(默认值为2592000(30天),单位秒)
show variables like '%expire%';

1 手工清除binlog

        删除binlog日志文件,切勿删除正在使用的binlog 所以删除旧的即可,不要全删。 不要轻易手动去删除binlog(指的是rm命令), 会导致binlog.index和真实存在的binlog不匹配,推荐使用purge命令予清除历史文件(purge命令目前来说不区分版本)。

# 将mysql-bin.009560之前的binlog清掉
purge binary logs to 'mysql-bin.009560';

# 指定时间之前的binlog清掉
purge binary logs before '2023-08-01 00:00:00';

2 MySQL5版本

2.1 临时生效,重启后失效

# 设置保留7天
set global expire_logs_days=7;
# 触发自动清理
flush logs;

2.2 永久有效,需要重启

修改配置文件my.cnf文件: vim /etc/my.cnf,在[mysqld]标签内增加如下内容

expire_logs_days=7
max_binlog_size=1024M

修改保存后,以下3种情况才生效:

  • MySQL启动时
  • 手动执行flush logs
  • 当binlog大小超过max_binlog_size
# 执行命令是配置生效
flush logs;

3 MySQL8版本

3.1 临时生效,重启后失效

# 设置保留7天
set global binlog_expire_logs_seconds=7*60*60*24;
# 触发自动清理
flush logs;

3.2 永久有效,需要重启

修改配置文件my.cnf文件: vim /etc/my.cnf,在[mysqld]标签内增加如下内容

# 设置保留7天
binlog_expire_logs_seconds=604800
max_binlog_size=1024M

生效条件见2.2模块 

  • 2
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

菜鸟程序员a

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值