设为首页 收藏本站
查看: 1089|回复: 0

[经验分享] mysql中的XtraBackup的备份原理

[复制链接]

尚未签到

发表于 2018-10-8 11:21:45 | 显示全部楼层 |阅读模式
  mysql中的XtraBackup的备份原理
  xtrabackup的官方下载地址为 :
http://www.percona.com/software/percona-xtrabackup。  xtrabackup包含两个主要的工具,即xtrabackup和innobackupex,二者区别如下:
1 xtrabackup只能备份innodb和xtradb两种引擎的表,而不能备份myisam引擎的表2 innobackupex是一个封装了xtrabackup的Perl脚本,支持同时备份innodb和myisam,但在对myisam备份时需要加一个全局的读锁。还有就是myisam不支持增量备份。  innobackupex工具的备份过程原理图
DSC0000.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数据或表空间,同时回滚未提交的事务
DSC0001.jpg

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

  增量备份的恢复
  和全库恢复类似,也需要两步
  1 数据文件的恢复 分3部分 全备 增量备份和xtrabackup_log
  2 对未提交事务的回滚
DSC0003.jpg

  innobackupex的使用案例
DSC0004.jpg

  1 创建备份用户
DSC0005.jpg

  进行数据库全备
DSC0006.jpg

  使用以下参数进行全库备份
DSC0007.jpg

  查看对应生成的文件
DSC0008.jpg

  需要注意的几个文件
DSC0009.jpg

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

  关闭数据库
DSC00011.jpg

  恢复
DSC00012.jpg

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

  更改权限
  [root@MASTER_03 tmp]# chown -R mysql.mysql /data/3306/data/
  启动mysqld
  [root@MASTER_03 tmp]# /etc/init.d/mysqld start
DSC00014.jpg

  发现数据是已经成功恢复
  先全备
DSC00015.jpg

  增量备份
DSC00016.jpg

  此时再插入数据
DSC00017.jpg

  增量备份2
DSC00018.jpg

  增量备份的恢复
  增量备份的恢复需要有3个步骤
  1 恢复完全备份
  2 恢复增量备份到完全备份(开始恢复的增量备份要添加--redo-only参数,到最后一次增量备份要去掉--redo-only)
  3 对整体的完全备份进行恢复,回滚未提交的数据
  模拟测试
DSC00019.jpg

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



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-616411-1-1.html 上篇帖子: centos7.x编译安装mysql5.7.16 下篇帖子: 编译安装MySQL5.5
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表