mysql的一些事件都以binary的格式存贮,通过mysqlbinlog这个工具来实现的。

mysqlbinlog可以用于Replication和数据库的恢复

这里主要是说一下mysqlbinlog日志的清理

mysqlbinlog日志的清除

mysql -uroot

PURGE {MASTER BINARY} LOGS TO ‘log_name’
PURGE {MASTER BINARY} LOGS BEFORE ‘date’

用于删除列于在指定的日志或日期之前的日志索引中的所有二进制日志。这些日志也会从记录在日志索引文件中的清单中被删除,这样被给定的日志成为第一个。

eg:

PURGE MASTER LOGS TO ‘mysql-bin.030’;

PURGE MASTER LOGS BEFORE ‘2009-01-10 11:00:00’;

清除N天前的 binlog

PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ), INTERVAL N DAY);

BEFORE变量的date自变量可以为’YYYY-MM-DD hh:mm:ss’格式。

将重复工作写到crontab里面去,即每天1:00执行清除3天前的binlog日志命令

0 1 * * *  mysql -uroot -e ‘PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ), INTERVAL 3 DAY);’

如果您有一个活动的slave服务器,该服务器当前正在读取您正在试图删除的日志之一,则本语句不会起作用,而是会失败,并伴随一个错误。不过,如果slave服务器是停止的,并且碰巧清理了slave想要读取的日志之一,则slave启动后不能复制。当slave正在复制时,本语句可以安全运行。

要清理日志,需按照以下步骤:

  1. 在每个slave服务器上,使用SHOW SLAVE STATUS来检查它正在读取哪个日志。

  2. 使用SHOW MASTER LOGS获得Master上的一系列日志。

  3. 在所有的slave中判定最早的日志。这个是目标日志。如果所有的slave是更新的,这是清单上的最后一个日志。

  4. 备份所有日志的。(这个步骤是自选的,但是建议采用。)

  5. 清理所有的日志,但是不包括目标日志