MySQL bin-log 日志清理方式

阿豪运维笔记 2020-01-25 873阅读

温馨提示:这篇文章已超过886天没有更新,请注意相关的内容是否还可用!

MySQL bin-log 作用

1.数据恢复:如果你的数据库出问题了,而你之前有过备份,那么可以看日志文件,找出是哪个命令导致你的数据库出问题了,想办法挽回损失。

2.主从服务器之间同步数据:主服务器上所有的操作都在记录日志中,从服务器可以根据该日志来进行,以确保两个同步。

3.在什么时间会删除过期日志?

每次进行 LOG flush的时会自动删除过期的日志,那么什么时间才能触发log flush,手册上的解释为:

重启 MySQL

bin-log 文件大小达到参数 max_binlog_size 限制;

手工执行清理命令

自动清理方法1:(修改配置文件和在mysql内设置参数可无需重启服务)

# vim my.cnf

expire_logs_days = 7 // 表示日志保留7天,超过7天则设置为过期的

# mysql -u root -p

> show binary logs;

> show variables like ‘%log%’;

> set global expire_logs_days = 7;

手动清理方法2:(推荐)

如果没有主从复制,可以通过下面的命令重置数据库日志,清除之前的日志文件:

reset master

但是如果存在复制关系,应当通过 PURGE 的名来清理 bin-log 日志,语法如下:

# mysql -u root -p

> purge master logs to ‘mysql-bin.010’; //清除mysql-bin.010日志

> purge master logs before ‘2016-02-28 13:00:00’; //清除2016-02-28 13:00:00前的日志

> purge master logs before date_sub(now(), interval 3 day); //清除3天前的bin日志

注意,不要轻易手动去删除binlog,会导致binlog.index和真实存在的binlog不匹配,而导致expire_logs_day失效


若文章图片、下载链接等信息出错,请联系反馈,博主将第一时间更新!如果喜欢本站,请打赏支持本站,谢谢!
文章版权声明:除非注明,否则均为阿豪运维笔记原创文章,转载或复制请以超链接形式并注明出处。

目录[+]

取消
微信二维码
微信二维码
支付宝二维码