zoukankan      html  css  js  c++  java
  • mysql 备份恢复

    mysql备份还原-基于binlog的增量备份还原

     
    1 简介
        基于binlog的恢复需要建立在全量备份恢复基础上。使用mysqldump的全量备份的方法在我前面的文章里有详细介绍,可以参考: http://blog.csdn.net/jesseyoung/article/details/41078947
        我们可以将增量的binlog备份下来,用来恢复增量数据。
    2 还原增量binlog的方法
        2.1 时间点的恢复建立在一下规则的基础上:

        1 mysql服务器需要开启二进制日志--log-bin
        查看所有binlog文件
    1. mysql> SHOW BINARY LOGS;  

        查看当前binlog文件信息(包含文件名,当前位置等)
    1. mysql> SHOW MASTER STATUS;  

        2 mysqlbinlog工具将binary log文件由二进制转换为可读的文本文件,可以选择基于时间或位置的事件。
        3 从binary log文件中执行事件会导致数据的修改,表示要重做数据。命令为:
    1. [root@localhost /]# mysqlbinlog binlog_files | mysql -u root -p  
        4 查看binlog的时间及位置信息我们可以讲binlog内容输出到终端或文本文件
    1. [root@localhost /]# mysqlbinlog binlog_files | more  
    2. [root@localhost /]# mysqlbinlog binlog_files > tmpfile  
        5 将二进制日志输出到文件非常有用,比如我们想要删除某些我们不想执行的语句。
        通过文本文件导入到数据库
    1. [root@localhost /]# mysql -u root -p < tmpfile  
        2.2 多个binlog log日志的还原最好将所有文件使用一个连接完成,如果使用不同连接的话有时会导致不安全
        例如:
    1. [root@localhost /]# mysqlbinlog binlog.000001 | mysql -u root -p # DANGER!!  
    2. [root@localhost /]# mysqlbinlog binlog.000002 | mysql -u root -p # DANGER!!  
        如果第一个日志包含创建临时表语句CREATE TEMPORARY TABLE,第二个日志要使用该临时表,第一个导入binlog日志的进程退出后临时表会被删除,执行第二个日志文件要使用临时表时会因找不到而报 “unknown table.”
        建议的方法:
        方法1:
        所有二进制文件放在单个连接里
    1. [root@localhost /]# mysqlbinlog binlog.000001 binlog.000002 | mysql -u root -p  
        方法2:
        将所有二进制文件写在一个文件里执行
    1. [root@localhost /]# mysqlbinlog binlog.000001 >  /tmp/statements.sql  
    2. [root@localhost /]# mysqlbinlog binlog.000002 >> /tmp/statements.sql  
    3. [root@localhost /]# mysql -u root -p -e "source /tmp/statements.sql"  
        使用方法二如果二进制文件里包含GTID信息需要过滤掉
    1. [root@localhost /]# mysqlbinlog --skip-gtids binlog.000001 >  /tmp/dump.sql  
    2. [root@localhost /]# mysqlbinlog --skip-gtids binlog.000002 >> /tmp/dump.sql  
    3. [root@localhost /]# mysql -u root -p -e "source /tmp/dump.sql"  
    3 通过时间点或位置点的恢复
        如果我们要跳过某个时间段或位置段,需要指定起止时间或位置信息
        3.1 通过事件的时间来恢复
        我们可以通过参数--start-datetime 和 --stop-datetime指定恢复binlog日志的起止时间点,时间使用DATETIME格式。
        比如在时间点2005-04-20 10:00:00我们删除掉一个库,我们要恢复该时间点前的所有日志
    1. [root@localhost /]# mysqlbinlog --stop-datetime="2005-04-20 9:59:59" /usr/local/mysql/data/binlog.123456 | mysql -u root -p  
        我们可能几个小时后才发现该错误,后面又有一系列的增删查改等操作,我们还需要恢复后续的binlog,我们可以指定起始时间
     
    1. [root@localhost /]# mysqlbinlog --start-datetime="2005-04-20 10:01:00" /usr/local/mysql/data/binlog.123456 | mysql -u root -p  

        通过该种方法恢复我们需要通过查看binlog日志知道发生误操作的确切时间点,查看日志我们可以先将日志输出到文本里

    1. [root@localhost /]# mysqlbinlog /usr/local/mysql/data/binlog.123456 > /tmp/mysql_restore.sql  
        3.2 通过事件的位置来恢复
        我们可以通过参数--start-position 和 --stop-position指定恢复binlog日志的起止位置点,通过位置的恢复需要我们有更加精细的操作,例如在某个时间点我们执行了错误的语句,且这个时间点前后都有大并发操作,要确定破坏性sql的时间点,我们可以先导出大致的时间段的日志到文件以缩小查找范围,再去分析和确定
    1. [root@localhost /]# mysqlbinlog --start-datetime="2005-04-20 9:55:00"  --stop-datetime="2005-04-20 10:05:00" /usr/local/mysql/data/binlog.123456 > /tmp/mysql_restore.sql  
        确定好需要跳过的位置之后,我们就可以进行恢复了
    1. [root@localhost /]# mysqlbinlog --stop-position=368312 /usr/local/mysql/data/binlog.123456 | mysql -u root -p  
    2. [root@localhost /]# mysqlbinlog --start-position=368315 /usr/local/mysql/data/binlog.123456 | mysql -u root -p  

        注:mysqlbinlog工具的输出会在每条sql语句前增加 SET TIMESTAMP语句,恢复的数据及mysql日志反映当前时间。

  • 相关阅读:
    深入理解javascript原型和闭包(3)——prototype原型
    深入理解javascript原型和闭包(2)——函数和对象的关系
    深入理解javascript原型和闭包(1)——一切都是对象
    js 基本类型与引用类型的区别
    一次完整的HTTP事务是怎样一个过程
    PHP+MySql+jQuery实现的“顶”和“踩”投票功能
    PHP获得真实客户端的真实时用到的IP REMOTE_ADDR,HTTP_CLIENT_IP,HTTP_X_FORWARDED_FOR
    Jenkins设置自动发邮件
    Jenkins+SVN+maven+Tomcat构建自动化集成任务
    Jenkins详细安装教程
  • 原文地址:https://www.cnblogs.com/kuku0223/p/8021885.html
Copyright © 2011-2022 走看看