定时清理mysql bin log

#!/bin/sh
mysql -ureplication -p123456 -h 127.0.0.1 -P3301 -e 'PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ),INTERVAL 5 DAY)';
mysql -ureplication -p123456 -h 127.0.0.1 -P3302 -e 'PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ),INTERVAL 5 DAY)';
exit

===================

 在Mysql中,如果启用mysql-bin日志记录,则Mysql的变更修改都会被记录到日志文件中:

mysql> show global variables like ‘%bin%’;
+———————————+———————-+
| Variable_name                   | Value                |
+———————————+———————-+
| binlog_cache_size               | 32768                |
| innodb_locks_unsafe_for_binlog  | OFF                  |
| log_bin                         | ON                   |
| log_bin_trust_function_creators | OFF                  |
| max_binlog_cache_size           | 18446744073709547520 |
| max_binlog_size                 | 104857600            |
| sync_binlog                     | 0                    |
+———————————+———————-+
7 rows in set (0.00 sec)

  如果使用了配置文件,则可以修改 /etc/my.cnf 把里面的log-bin这一行注释掉,重启mysql服务即可关闭bin日志的记录。

  一个客户的数据库,积累了大量的bin日志:

mysql> show binary logs;
+——————+———–+
| Log_name         | File_size |
+——————+———–+
| mysql-bin.000064 |   3175623 |
| mysql-bin.000065 | 104857696 |
| mysql-bin.000066 |  30124812 |
| mysql-bin.000067 | 104857882 |
+——————+———–+
240 rows in set (0.00 sec)

  如果没有主从复制,可以通过reset master的方式,重置数据库日志,清除之前的日志文件:

  mysql> reset master;
  Query OK, 0 rows affected (8.51 sec)

  但是如果存在复制关系,应当通过PURGE的方式来清理bin日志:

  语法如下:

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

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

  例如:

  PURGE MASTER LOGS TO ‘mysql-bin.010′;
  PURGE MASTER LOGS BEFORE ’2008-06-23 15:00:00′;

  清除3天前的 binlog

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

  BEFORE变量的date自变量可以为’YYYY-MM-DD hh:mm:ss’格式。MASTER和BINARY是同义词。

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

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

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

  2. 使用SHOW MASTER LOGS获得主服务器上的一系列日志。

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

  4. 制作您将要删除的所有日志的备份。(这个步骤是自选的,但是建议采用。)

  5. 清理所有的日志,但是不包括目标日志,因为从服务器还要跟它同步

  常用的命令:

  mysql>show slave hosts — 查看所有连接到Master的Slave信息

  mysql>show master status — 查看Master状态信息

  mysql>show slave status — 查看Slave状态信息

  mysql>show binary logs — 查看所有二进制日志

  mysql>show binlog events [IN log_file] — 查看二进制日志中的事件

猜你喜欢

转载自zhengdl126.iteye.com/blog/1522197