ITPub博客

首页 > Linux操作系统 > Linux操作系统 > mysql binlog管理

mysql binlog管理

原创 Linux操作系统 作者:longqidong 时间:2012-07-18 13:54:11 0 删除 编辑

 查看数据库的日记信息:

1.mysql> show binary logs;

mysql> show binary logs;

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

| Log_name         | File_size |

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

| mysql-bin.000009 |       125 |

| mysql-bin.000010 |       644 |

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

2.删除bin-log(删除mysql-bin.000010之前的而没有包含 mysql-bin.000010)

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

Query OK, 0 rows affected (0.16 sec)

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

mysql> show binary logs;

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

| Log_name         | File_size |

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

| mysql-bin.000010 |       644 |

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

1 row in set (0.00 sec)

(  mysql-bin.000009 已被删除)

 命令说明

 PURGE {MASTER | BINARY} LOGS TO 'log_name'

 PURGE {MASTER | BINARY} LOGS BEFORE 'date'

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


  例如

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

  PURGE MASTER LOGS BEFORE '2012-07-17 13: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';

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

 

四 配置选项

但没有看到删除的配置mysqlshow了一下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

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/22418990/viewspace-735924/,如需转载,请注明出处,否则将追究法律责任。

上一篇: bash中字符串判断
下一篇: ora-16014
请登录后发表评论 登录
全部评论

注册时间:2009-08-26

  • 博文量
    94
  • 访问量
    412780