学习mysql binlog日志清理

发布时间:2019-07-23编辑:脚本学堂
学习mysql中binlog日志清理的一些记录,有需要的朋友,可以参考下。

一、查看数据库的日记信息:
1)、

复制代码 代码示例:
mysql> show binary logs;
+----------------+-----------+
| Log_name       | File_size |
+----------------+-----------+
| ablelee.000001 | 150462942 |
| ablelee.000002 |       125 |
| ablelee.000003 |       106 |
+----------------+-----------+

2)、删除bin-log(删除ablelee.000003之前的而没有包含ablelee.000003)
 

复制代码 代码示例:
mysql> purge binary logs to 'ablelee.000003';
Query OK, 0 rows affected (0.16 sec)

3)、查询结果(现在只有一条记录了.)
 

复制代码 代码示例:
mysql> show binlog eventsG
*************************** 1. row ***************************
   Log_name: ablelee.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)
(ablelee.000001和ablelee.000002已被删除)
mysql> show binary logs;
+----------------+-----------+
| Log_name       | File_size |
+----------------+-----------+
| ablelee.000003 |       106 |
+----------------+-----------+
1 row in set (0.00 sec)

二、命令说明
 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. 清理所有的日志

另外一个办法,就是可以先:
 

复制代码 代码示例:
flush logs
 

再运行:
 

复制代码 代码示例:
pure master logs xxx

flush logs之后会产生一个新的日志,老的日志重新生成一个文件。
比如你现在有一个大日志有800M,叫bin-log.00001
flush logs之后,就有两个文件bin-log.00001和bin-log.00002新的日志只写到bin-log.00002中

slave中的信息也自动指向bin-log.00002,这时候再
 

复制代码 代码示例:
purge master logs to 'bin-log.00002';

就能把老的那个删除,达到你所描述的目的。master和slave都很安全。

四、配置选项
但没有看到删除的配置,在mysql里show了一下variables,
 

复制代码 代码示例:
mysql> show variables like '%log%';

查到了
| expire_logs_days   | 0  |
这个默认是0,也就是logs不过期,这个是一个global的参数,所以需要执行

复制代码 代码示例:
set global expire_logs_days=8;

这样8天前的log就会被删除了,如果有回复的需要,请做好备份工作,但这样设置还不行,下次重启mysql了,配置又恢复默认了,所以需在my.cnf中设置

复制代码 代码示例:
expire_logs_days = 8

您可能感兴趣的文章:
自动与手动清理mysql-binlog日志的方法
mysqldump使用binlog二进制日志进行备份的例子
mysql设置自动清理binlog日志的方法
mysql删除binlog日志及使用日志恢复数据的方法
理解Mysql binlog 日志的三种模式
删除Mysql中binlog日志的二种方法
使用binlog恢复mysql数据的简单例子
如何在mysqldump时加上binlog日志的位置号