想要恢愎数据库以前的资料,执行:show binlog events;屏幕就开始闪,闪的人眼花,心里烦(那有这么多没有用的破LOG^0^),还是删除一些去吧!
列出当前的binlog文件
1
2
3
4
5
6
7
8
9mysql> show binary logs;
+------------------+-----------+
| Log_name | File_size |
+------------------+-----------+
| mysql-bin.000001 | 150462942 |
| mysql-bin.000002 | 125 |
| mysql-bin.000003 | 106 |
+------------------+-----------+
3 rows in set (0.00 sec)删除bin-log(删除mysql-bin.000003之前的而没有包含mysql-bin.000003)
1
2mysql> purge binary logs to 'mysql-bin.000003';
Query OK, 0 rows affected (0.16 sec)查询结果(现在只有一条记录了.)
1
2
3
4
5
6
7
8
9mysql> show binlog events\G
*************************** 1. row ***************************
Log_name: mysql-bin.000003
Pos: 4
Event_type: Format_desc
Server_id: 1
End_log_pos: 106
Info: Server ver: 5.1.26-rc-log, Binlog ver: 4
1 row in set (0.01 sec)(mysql-bin.000001和mysql-bin.000002已被删除)
1 | mysql> show binary logs; |
(删除的其它格式运用!)
1 | PURGE {MASTER | BINARY} LOGS TO 'log_name' |
用于删除列于在指定的日志或日期之前的日志索引中的所有二进制日志。这些日志也会从记录在日志索引文件中的清单中被删除,这样被给定的日志成为第一个。
例如:
1 | PURGE MASTER LOGS TO 'mysql-bin.010'; |
清除3天前的 binlog
1 | PURGE MASTER LOGS BEFORE DATE_SUB( NOW( ), INTERVAL 3 DAY); |
BEFORE变量的date自变量可以为’YYYY-MM-DD hh:mm:ss’格式。MASTER和BINARY是同义词。
如果您有一个活性的从属服务器,该服务器当前正在读取您正在试图删除的日志之一,则本语句不会起作用,而是会失败,并伴随一个错误。不过,如果从属服务器是休止的,并且您碰巧清理了其想要读取的日志之一,则从属服务器启动后不能复制。当从属服务器正在复制时,本语句可以安全运行。您不需要停止它们。
要清理日志,需按照以下步骤:
- 在每个从属服务器上,使用
SHOW SLAVE STATUS
来检查它正在读取哪个日志。 - 使用
SHOW MASTER LOGS
获得主服务器上的一系列日志。 - 在所有的从属服务器中判定最早的日志。这个是目标日志。如果所有的从属服务器是更新的,这是清单上的最后一个日志。
- 制作您将要删除的所有日志的备份。(这个步骤是自选的,但是建议采用。)
- 清理所有的日志,但是不包括目标日志我。