zoukankan      html  css  js  c++  java
  • 从binlog恢复数据及Mysqlbinlog文件删除

    做了mysql主从也有一段时间了,这两天检查磁盘空间情况,发现放数据库的分区磁盘激增了40多G,一路查看下来,发现配置好主从复制以来到现在的binlog就有40多G,原来根源出在这里,查看了一下my.cnf,看到binlog的size是1G就做分割,但没有看到删除的配置,在mysql里查看了一下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>show binlog events;
    由于数据量很多,查看起来很麻烦,光打开个文件就要闪半天,所以应该适当删除部分可不用的日志。
    并且如果使用的时间足够长的话,会把我的硬盘空间都给吃掉
    1、登录系统,/usr/bin/mysql
    使用mysql查看日志
    mysql>show binary logs;
    +—————-+———–+
    | Log_name        | File_size |
    +—————-+———–+
    | ablelee.000001 | 150462942 |
    | ablelee.000002 | 120332942 |
    | ablelee.000003 | 141462942 |
    +—————-+———–+

    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-22 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. 清理所有的日志,但是不包括目标日志。

    下面讲一下怎么从二进制文件恢复数据, 假如不小心执行了drop table xxx_db, 假如你保留了完整的二进制日志的话, 先不要冒汗, 这是可以恢复的.
    先看看日志
    #mysqlbinlog /diskb/bin-logs/xxx_db-bin.000001
    找到执行create table xxx_db之后和drop table xxx_db之前的position, 假如是20, 1000
    #mysqlbinlog --start-position="4" --stop-position="1000" /diskb/bin-logs/xxx_db-bin.000001 | mysql -u root

    伴随着一大堆的ERROR 1062 (23000) at line 12355: Duplicate entry '139' for key 1, 数据库就这样恢复了, 不过--start-position="20"是不行的, 必须从--start-position="4"开始, 为什么要强制从4开始, 这个问题我也暂时没有搞清楚.
    还有一种办法是根据日期来恢复
    #mysqlbinlog --start-datetime="2009-09-14 0:20:00" --stop-datetim="2009-09-15 01:25:00" /diskb/bin-logs/xxx_db-bin.000001 | mysql -u root
    如果create table xxx_db和drop table xxx_db之间的时间相距是一年, 或者在不同的二进制日志中, 且位置相距好远, 就等着失眠吧! 做好备份, 小心操作才是正路啊!

    http://www.jzxue.com/shujuku/mysql/201102/22-6298.html

  • 相关阅读:
    iOS
    UI基本视图控制
    堆和栈的区别 ?
    单例模式
    Object-c的类可以多重继承么?可以实现多个接口么?Category是什么?重写一个类的方式用继承好还是分类好?为什么?
    id
    协议
    分类(类别)
    #import和#include以及@class三者的区别?
    内存管理
  • 原文地址:https://www.cnblogs.com/seasonsstory/p/3274610.html
Copyright © 2011-2022 走看看