mysql中XtraBackup备份讲义

  

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

,,,, xtrabackup包含两个主要的工具,即xtrabackup和innobackupex,二者区别如下:

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


 1,首先会启动一个xtrabackup_log后台检测的进程,实时检测mysql 重做的变化,一旦发现重做有新的日志写入,立刻将日志写入到日志文件xtrabackup_log中
  
  2,复制innodb的数据文件和系统表空间文件idbdata1到对应的以默认时间戳为备份目录的地方
  
  3,复制结束后,执行flush  table  with  read 锁操作
  
  4,复制.frm  .myd  .myi文件
  
  5,并且在这一时刻获得binary  log 的位置
  
  6,将表进行解锁unlock 表
  
  7,停止xtrabackup_log进程
  
  全库恢复的过程
  这一阶段会启动xtrabackup内嵌的innodb实例,将xtrabackup日志xtrabackup_Log进行回放,将提交的事务信息变更应用到innodb数据或表空间,同时回滚未提交的事务

    mysql中XtraBackup备份讲义        

 

增量备份

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

        

    mysql中XtraBackup备份讲义    

增量备份的恢复

和全库恢复类似,也需要两步

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

2 对未提交事务的回滚

mysql中XtraBackup备份讲义    

        innobackupex的使用案例

    mysql中XtraBackup备份讲义

1 创建备份用户

 mysql中XtraBackup备份讲义       

mysql中XtraBackup备份讲义        

mysql中XtraBackup备份讲义    

查看对应生成的文件

mysql中XtraBackup备份讲义            

需要注意的几个文件    

mysql中XtraBackup备份讲义

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

mysql中XtraBackup备份讲义    

关闭数据库

mysql中XtraBackup备份讲义    

恢复

mysql中XtraBackup备份讲义        

以上对应的目录就是innobackupex全备份自己创建的目录

mysql中XtraBackup备份讲义     

更改权限

 

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

启动mysqld

(root@MASTER_03 tmp) #/etc/init.d/mysqld开始

 mysql中XtraBackup备份讲义”>,,,,,,,,,,,,,,,,</p> <p> <br/> </p> <p>发现数据是已经成功恢复<h2 class=mysql中XtraBackup备份讲义