快捷搜索: 王者荣耀 脱发

全量+增量的备份/恢复(dumpxtrabackup)

 生产环境中,有时需要做MySQL的备份和恢复工作。因MySQL是在运行过程中的,做全量备份需要时间,全量备份完成后又有数据变动,此时需要增量备份辅助。如果想恢复数据到一个空库(例如数据迁移或者上云等更换MySQL数据库的场景),基于全量备份+增量备份的数据进行恢复,可以更接近于原本的数据。

  工作中曾经使用过的2种方法:

1.基于dump全量备份.sql+binlog生成增量备份sql,进行全量+增量的备份/恢复操作。

    备份过程:

  (1)dump命令,生成全量备份sql文件。

  (2)查看全量备份文件.sql,注意这个信息:

  (3)全量备份之后,MySQL中又有增删改操作。例如:再create一个表,并插入数据。

  (4)增量备份:执行flush logs,会生成最新的增量binlog。

    恢复过程:

  (1)dump出来的全量备份文件.sql 和 flush出来的增量binlog 都scp拷贝到要恢复的机器上。

  (2)恢复dump全量备份:mysql -uroot -p密码 数据库名 < 全量备份.sql

  (3)基于binlog生成增量备份sql:mysqlbinlog --start-position=337 --database=数据库名 mysql-bin.000002 > 增量备份.sql

  (4)执行恢复该增量备份sql:mysql -uroot -p密码 数据库名 < 增量备份.sql

2.基于Percona公司的xtrabackup工具,进行全量+增量的备份/恢复操作。

   (1)全量备份

    innobackupex --user=用户名 --password=密码 全量备份文件存放目录。

    同样,期间有些增量操作,建表,增删数据等

  (2)增量备份

    innobackupex --user=用户名 --password=密码 --incremental 增量备份文件存放目录 --incremental-basedir=依赖的上一次全量备份或增量备份

  (3)恢复日志的准备

    增量恢复日志的准备

    innobackupex --apply-log --redo-only 全量备份文件存放目录

    innobackupex --apply-log --redo-only 全量备份文件存放目录 --incremental-dir=增量备份文件存放目录

    全量恢复日志的准备

    innobackupex --apply-log 全量备份文件存放目录

  (4)恢复数据

    关闭要恢复的数据库

    /etc/init.d/mysqld stop

    mv data data_old

    mv undo undo_old

    mv undo_log undo_log_old

    mkdir -p data undo_log

    innobackupex --move-back 全量备份文件存放目录

    chown mysql:mysql -R data/

    chown mysql:mysql -R undo_log/

    /etc/init.d/mysqld start

经验分享 程序员 微信小程序 职场和发展