zoukankan      html  css  js  c++  java
  • 通过innobackupex实现对MySQL的增量备份与还原

    备份

    增量备份是基于完整备份的,所以我们需要先做一次完整备份:

    innobackupex --password=test /backup/

    备注:test是我的MySQL服务的root用户的密码,/backup/是我用于存放备份文件的目录。

    执行完命令后,/backup/目录下会生成一个时间戳目录,在我这个例子中是/backup/2016-09-20_14-45-26/。

    第一次增量备份:

    innobackupex --password=test --incremental /backup/ --incremental-basedir=/backup/2016-09-20_14-45-26/

    注意:第一次备份的--incremental-basedir参数应指向完整备份的时间戳目录。

    执行完命令后,/backup/目录下会生成一个时间戳目录,在我这个例子中是/backup/2016-09-20_14-58-01/。

    第二次增量备份:

    innobackupex --password=test --incremental /backup/ --incremental-basedir=/backup/2016-09-20_14-58-01/

    注意:第二次备份的--incremental-basedir参数应指向第一次增量备份的时间戳目录。

    执行完命令后,/backup/目录下会生成一个时间戳目录,在我这个例子中是/backup/2016-09-20_14-58-30/。

    为了达到实验效果,建议读者在每次增量备份前对数据库进行增删改,以便观察还原效果。

    还原

    停止MySQL服务并清空数据目录:

    service mysqld stop
    rm -rf /mysql/*

    整合完整备份和增量备份:

    innobackupex --apply-log --redo-only /backup/2016-09-20_14-45-26/
    innobackupex --apply-log --redo-only /backup/2016-09-20_14-45-26/ --incremental-dir=/backup/2016-09-20_14-58-01/
    innobackupex --apply-log /backup/2016-09-20_14-45-26/ --incremental-dir=/backup/2016-09-20_14-58-30/
    innobackupex --apply-log /backup/2016-09-20_14-45-26/

    注意:一定要按照完整备份、第一次增量备份、第二次增量备份的顺序进行整合,在整合最后一次增量备份时不要使用--redo-only参数。

    开始还原:

    innobackupex --copy-back /backup/2016-09-20_14-45-26/

    还原成功后你会看到“completed OK!”的字样。

    修改数据目录的属主和属组并启动MySQL服务:

    chown -R mysql.mysql /mysql/
    service mysqld start

    通过以上步骤就完成了增量备份的还原。

    温馨提示

    在还原时,如果有足够的空间,建议对数据目录和备份目录进行拷贝备份。

  • 相关阅读:
    GOF23设计模式汇总
    获取表单提交MVC错误信息
    Spring.Net
    简单工厂、工厂方法和抽象工厂
    Json和JsonP
    mysql8无法用navicat连接(mysql8加密方式的坑)
    (4.16)mysql备份还原——物理备份之XtraBackup实践
    mysql如何下载历史版本?
    如何测试端口通不通(四种方法)
    linux移动复制删除命令
  • 原文地址:https://www.cnblogs.com/yestreenstars/p/5889079.html
Copyright © 2011-2022 走看看