当mysql 日志占用太大空间的时候,要考虑将日志删除
PURGE {MASTER | BINARY} LOGS TO 'log_name' PURGE {MASTER | BINARY} LOGS BEFORE 'date' 用于删除在指定的日志或日期之前的日志索引中的所有二进制日志。这些日志也会从记录在日志索引文件中的清单中被删除,这样被给定的日志成为第一个。
PURGE MASTER LOGS TO 'mysql-bin.010'; +------------------+-----------+
+------------------+-----------+
| 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-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 |
+------------------+-----------+
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 | |
+------------------+-----+-------------+-----------+-------------+---------------------------------------+
PURGE MASTER LOGS BEFORE '2011-12-05 13:00:00';
PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ), INTERVAL N DAY);
BEFORE变量的date自变量可以为'YYYY-MM-DD hh:mm:ss'格式。MASTER和BINARY是同义词。
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服务器是更新的,这是清单上的最后一个日志。
配置文件my.cnf的参数expire-logs-days 指定了日志过期的天数,比如
expire-logs-days = 20 表示日志保留20,超过20则设置为过期的!可以根据实际情况来设置合适的值。