首页 > 数据库技术 > 详细

MySQL Binlog和Relaylog生成和清理

时间:2019-02-15 13:59:04      阅读:480      评论:0      收藏:0      [点我收藏+]

=====================================================================================
binlog文件生成:
在每条二进制日志写入到日志文件后,会判断该文件是否超过max_binlog_size,如果超过则生成一个新的binlog


=====================================================================================
binlog文件删除:
1>当使用RESET MASTER命令后,会清空全部二进制日志
命令:RESET MASTER;

2>当执行PURGE MASTER LOG TO命令后,会删除指定binlog以及之前的二进制日志
命令:PURGE MASTER LOGS TO ‘binlog file name‘;

3>当执行PURGE MASTER LOG BEFORE 命令后,会删除指定时间前的所有二进制
命令:PURGE MASTER LOGS TO ‘datetime‘;

4>当实例启动或执行flush logs时,按照expire_logs_days设置,如果超过该参数指定天数的二进制会被全部删除
命令:mysqladmin flush-log


=====================================================================================
清理binlog文件顺序:
先从文件系统中清理文件,再修改索引文件。


=====================================================================================
Relay Log rotate 机制:
Rotate:每从Master fetch一个events后,判断当前文件是否超过max_relay_log_size 如果超过则自动生成一个新的relay-log-file
Delete: purge-relay-log 在SQL Thread每执行完一个events时判断,如果该relay-log 已经不再需要则自动删除
Delete: expire-logs-days 只在 实例启动时 和 flush logs 时判断,如果文件访问时间早于设定值,则purge file (同Binlog file) (updated: expire-logs-days和relaylog的purge没有关系)
PS: 因此还是建议配置 expire-logs-days , 否则当我们的外部脚本因意外而停止时,还能有一层保障。



MySQL Binlog和Relaylog生成和清理

原文:https://www.cnblogs.com/gaogao67/p/10383221.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!