当前位置: 代码迷 >> MySQL >> MySql怎么删除 bin log
  详细解决方案

MySql怎么删除 bin log

热度:167   发布时间:2016-05-05 17:12:26.0
MySql如何删除 bin log

【MySql】如何删除 bin log

?

?

一 语法如下:

?

PURGE {MASTER | BINARY} LOGS TO 'log_name'

?

PURGE {MASTER | BINARY} LOGS BEFORE 'date'

?

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

?

例如:

?

1 删除指定日志之前的bin log

?

PURGE MASTER LOGS TO 'mysql-bin.010';

?

1) 查看当前的log

?

mysql> show binary logs;

?

+------------------+-----------+

?

| Log_name ? ? ? ? | File_size |

?

+------------------+-----------+

?

| mysql-bin.000001 | ? ? ? 126 |

?

| mysql-bin.000002 | ?88416282 |

?

| mysql-bin.000003 | 198081520 |

?

| mysql-bin.000004 | ? ? ?1358 |

?

| mysql-bin.000005 | ? ? ? 126 |

?

| mysql-bin.000006 | ? ? ? 126 |

?

| mysql-bin.000007 | ? ? ? 126 |

?

| mysql-bin.000008 | ? ? ? 315 |

?

| mysql-bin.000009 | ? ? ? 126 |

?

| mysql-bin.000010 | ? ? ? 126 |

?

| mysql-bin.000011 | ? ? ? 504 |

?

| mysql-bin.000012 | ? ? ? 107 |

?

| mysql-bin.000013 | ? ? ? 107 |

?

| mysql-bin.000014 | ? ? ? 107 |

?

| mysql-bin.000015 | ? ? ? 107 |

?

| mysql-bin.000016 | ? ? ? 521 |

?

| mysql-bin.000017 | ? ? ? 315 |

?

| mysql-bin.000018 | ? ? ? 958 |

?

+------------------+-----------+

?

18 rows in set (0.04 sec)

?

2) 删除mysql-bin.000010 之前的日志

?

mysql> purge binary logs to 'mysql-bin.000010';

?

Query OK, 0 rows affected (0.35 sec)

?

mysql> show binary logs; ? ? ? ? ? ? ? ? ? ? ??

?

+------------------+-----------+

?

| Log_name ? ? ? ? | File_size |

?

+------------------+-----------+

?

| mysql-bin.000010 | ? ? ? 126 |

?

| mysql-bin.000011 | ? ? ? 504 |

?

| mysql-bin.000012 | ? ? ? 107 |

?

| mysql-bin.000013 | ? ? ? 107 |

?

| mysql-bin.000014 | ? ? ? 107 |

?

| mysql-bin.000015 | ? ? ? 107 |

?

| mysql-bin.000016 | ? ? ? 521 |

?

| mysql-bin.000017 | ? ? ? 315 |

?

| mysql-bin.000018 | ? ? ? 958 |

?

+------------------+-----------+

?

9 rows in set (0.00 sec)

?

3)显示第一个二进制日志:?

?

mysql>show binlog events;

?

+------------------+-----+-------------+-----------+-------------+---------------------------------------+

?

| Log_name ? ? ? ? | Pos | Event_type ?| Server_id | End_log_pos | Info ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?|

?

+------------------+-----+-------------+-----------+-------------+---------------------------------------+

?

| mysql-bin.000010 | ? 4 | Format_desc | ? ? ? ? 1 | ? ? ? ? 107 | Server ver: 5.5.18-log, Binlog ver: 4 |

?

| mysql-bin.000010 | 107 | Stop ? ? ? ?| ? ? ? ? 1 | ? ? ? ? 126 | ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? |

?

+------------------+-----+-------------+-----------+-------------+---------------------------------------+

?

2 rows in set (0.01 sec)

?

2 删除指定日期之前的bin log

?

PURGE MASTER LOGS BEFORE '2011-12-05 13:00:00';

?

3 清除N天前的 binlog

?

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

?

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

?

下面的语句可以清除 7 天前的binlog,

?

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

?

在contab设置定期每天凌晨3点删除7天前的binlog:

?

0 3 * * * ?`mysql -uroot -e 'PURGE BINARY LOGS BEFORE DATE_SUB( NOW( ), INTERVAL 7 DAY);'`

?

?

?

二 主从架构的日志删除

?

对 于主从结构的mysql系统,slave服务器当前正在读取试图删除的日志之一,则删除语句失败,并且报错。不过,如果在slave服务器是停止运行期间 清理了其未读取的日志之一,则slave服务器启动后不能复制。当slave服务器正在复制时,删除日志的语句可以安全运行,并不需要停止它们。

?

主从架构的可以按照以下步骤清理日志:

?

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

?

2. 使用SHOW MASTER LOGS获得主服务器上的已经归档的日志。

?

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

?

4. 备份将要删除的所有日志,防止意外!

?

5. 删除日志,但不包括目标日志。

?

三 相关参数:

?

? 配置文件my.cnf的参数expire-logs-days 指定了日志过期的天数,比如

?

expire-logs-days ?= 20 表示日志保留20,超过20则设置为过期的!可以根据实际情况来设置合适的值。
  相关解决方案