Chinaunix首页 | 论坛 | 博客
  • 博客访问: 3049128
  • 博文数量: 535
  • 博客积分: 15788
  • 博客等级: 上将
  • 技术积分: 6507
  • 用 户 组: 普通用户
  • 注册时间: 2007-03-07 09:11
文章分类

全部博文(535)

文章存档

2016年(1)

2015年(1)

2014年(10)

2013年(26)

2012年(43)

2011年(86)

2010年(76)

2009年(136)

2008年(97)

2007年(59)

分类: Mysql/postgreSQL

2010-11-25 15:16:26

摘自:
使用 purge master而不要使用reset master

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';

不生效?
Query OK, 0 rows affected, 1 warning (0.00 sec)?
mysql> show warnings;
 Warning | 1292 | Incorrect datetime value: '20140403 12:10: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. 清理所有的日志,但是不包括目标日志我


1、清除master上的binary log
你可以先在master上执行
flush logs
再运行
pure master logs xxx

这样就能达到你的目的了,而且也非常安全。
flush logs之后会产生一个新的日志,老的日志重新生成一个文件。
比如你现在有一个大日志有800M,叫bin-log.000013,还有12个1.1G的bin-log
flush logs之后,就会出现bin-log.000014新的日志只写到bin-log.000014中

slave中的信息也自动指向bin-log.000014,这时候再
purge master logs to 'bin-log.000014'; 
就能把老的那些删除,达到你所描述的目的。master和slave都很安全。

2、清除slave上的binary log
slave 上直接执行purge master logs to 'bin-log.000003';就可以了,关于最新的是那个bin-log, 

mysql> show binary logs;
+------------------+-----------+
| Log_name | File_size |
+------------------+-----------+
| mysql-bin.000002 | 125 |
| mysql-bin.000003 | 106 |
+------------------+-----------+
2 rows in set (0.00 sec)




注,不要再slave上运行reset master,这会让slave变成master,如果运行了,最保险的还是重新库导,然后重新执行change master to 来设置为slave,
当然也不要再master上运行reset master,这样的话会造成master清空binlog,并创建新的binlog,而slave还停留在老的binlog,造成主从失败。
RESET SLAVE用于让从属服务器忘记其在主服务器的二进制日志中的复制位置。本语句被用于进行一个明确的启动:它会删除master.inforelay-log.info文件,以及所有的中继日志,并启动一个新的中继日志。

12.6.1.2. RESET MASTER Syntax
RESET MASTER
Deletes all binary logs listed in the index file, resets the binary log index file to be empty, and creates a new binary log file.


阅读(2583) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~