mysql中的XtraBackup的备份原理

mysql中的XtraBackup的备份原理mysql

xtrabackup的官方下载地址为 :  sql

http://www.percona.com/software/percona-xtrabackup。

    xtrabackup包含两个主要的工具,即xtrabackup和innobackupex,两者区别以下:数据库

1 xtrabackup只能备份innodb和xtradb两种引擎的表,而不能备份myisam引擎的表
2 innobackupex是一个封装了xtrabackup的Perl脚本,支持同时备份innodb和myisam,但在对myisam备份时须要加一个全局的读锁。还有就是myisam不支持增量备份。

      innobackupex工具的备份过程原理图   
ide

wKiom1lh5BLx9EeFAAFqJE2_UBo591.jpg


    如图,备份开始的时候
工具

1 首先会启动一个xtrabackup_log后台检测的进程,实时检测mysql redo的变化,一旦发现redo有新的日志写入,马上将日志写入到日志文件xtrabackup_log中

2 复制innodb的数据文件和系统表空间文件idbdata1到对应的以默认时间戳为备份目录的地方

3 复制结束后,执行flush table with read lock操做

4 复制.frm .myd .myi文件

5 而且在这一时刻得到binary log 的位置

6 将表进行解锁unlock tables

7 中止xtrabackup_log进程

全库恢复的过程
这一阶段会启动xtrabackup内嵌的innodb实例,将xtrabackup日志xtrabackup_Log进行回放,将提交的事务信息变动应用到innodb数据或表空间,同时回滚未提交的事务

    wKioL1lh5E2TbZ-7AACE0FG0D4k802.jpg        

 

增量备份测试

增量备份主要是经过拷贝innodb中有变动的页(指的是LSN大于xtrabackup_checkpoints中的LSN号)。增量备份是基于全备的,第一次增量备份的数据是基于上一次全备,以后的每一次增倍都是基于上一次的增倍,最终达到一致性的增倍,增倍的过程当中,和全备很相似,区别在于第二步spa

        

    wKioL1lh5GuA-B2xAAFH7_lDh3U535.jpg    

增量备份的恢复3d

和全库恢复相似,也须要两步日志

1 数据文件的恢复 分3部分 全备 增量备份和xtrabackup_logblog

2 对未提交事务的回滚

wKioL1lh5Iix38qCAACuPmccu3o754.jpg    

        innobackupex的使用案例

    wKiom1lh5KKBQsjTAAA8hUfupb8778.jpg

1 建立备份用户

 wKiom1lh5LWi3kmjAABIoGmhsmE760.jpg       

进行数据库全备

wKioL1lh5NKhjUSUAAAimVXNPm0105.jpg        

使用如下参数进行全库备份

wKiom1lh5OTz-jCVAAHUqrChj5k724.jpg    

查看对应生成的文件

wKioL1lh5P-i4_wOAAHcwDEQ1EY575.jpg            

须要注意的几个文件    

wKiom1lh5RCwmHiqAAC4ogRJIJw502.jpg

删掉某个数据库,进行全库恢复

wKioL1lh5SPxPw38AAAoPzOa2jc849.jpg    

关闭数据库

wKioL1lh5TOg-6CoAAB200IMMjI851.jpg    

恢复

wKiom1lh5UqToLoUAADAU8aTrTU922.jpg        

以上对应的目录就是innobackupex全备份本身建立的目录

wKioL1lh5WPAolQRAAE6q4s4Ydw620.jpg     

更改权限

 

[root@MASTER_03 tmp]# chown -R mysql.mysql /data/3306/data/

启动mysqld

[root@MASTER_03 tmp]# /etc/init.d/mysqld start

wKiom1lh5ZGBLmvuAAFEo7oZ5u0281.jpg                


发现数据是已经成功恢复

    

    先全备

wKioL1lh5b6TT1a_AABsqVBfPxY623.jpg    

增量备份

wKioL1lh5dKQleBnAAF8V7jd6wo026.jpg    


此时再插入数据

wKioL1lh5fSR6wh7AAA1NTDr8Dw307.jpg

增量备份2

wKioL1lh5gDAPIkNAAChi-o3IWw538.jpg  

增量备份的恢复

增量备份的恢复须要有3个步骤

1 恢复彻底备份

2 恢复增量备份到彻底备份(开始恢复的增量备份要添加--redo-only参数,到最后一次增量备份要去掉--redo-only)

3 对总体的彻底备份进行恢复,回滚未提交的数据

          

模拟测试

wKiom1lh5jzQEBjsAAD-pUJSH-k755.jpg

测试完毕,恢复仍是比较简单的。

相关文章
相关标签/搜索