【MySQL】全量+增量的备份/恢复

  生产环境中,有时需要做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生成增量备份sqlmysqlbinlog --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

 

posted @ 2019-05-24 23:03  wwcom123  阅读(2887)  评论(2编辑  收藏  举报