十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
本文主要给大家介绍mysql中XtraBackup备份讲义,其所涉及的东西,从理论知识来获悉,有很多书籍、文献可供大家参考,从现实意义角度出发,创新互联累计多年的实践经验可分享给大家。
创新互联专业为企业提供天坛街道网站建设、天坛街道做网站、天坛街道网站设计、天坛街道网站制作等企业网站建设、网页设计与制作、天坛街道企业网站模板建站服务,10多年天坛街道做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。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工具的备份过程原理图
如图,备份开始的时候
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数据或表空间,同时回滚未提交的事务
增量备份
增量备份主要是通过拷贝innodb中有变更的页(指的是LSN大于xtrabackup_checkpoints中的LSN号)。增量备份是基于全备的,第一次增量备份的数据是基于上一次全备,之后的每一次增倍都是基于上一次的增倍,最终达到一致性的增倍,增倍的过程中,和全备很类似,区别在于第二步
增量备份的恢复
和全库恢复类似,也需要两步
1 数据文件的恢复 分3部分 全备 增量备份和xtrabackup_log
2 对未提交事务的回滚
innobackupex的使用案例
1 创建备份用户
进行数据库全备
使用以下参数进行全库备份
查看对应生成的文件
需要注意的几个文件
删掉某个数据库,进行全库恢复
关闭数据库
恢复
以上对应的目录就是innobackupex全备份自己创建的目录
更改权限
[root@MASTER_03 tmp]# chown -R mysql.mysql /data/3306/data/
启动mysqld
[root@MASTER_03 tmp]# /etc/init.d/mysqld start
发现数据是已经成功恢复
先全备
增量备份
此时再插入数据
增量备份2
增量备份的恢复
增量备份的恢复需要有3个步骤
1 恢复完全备份
2 恢复增量备份到完全备份(开始恢复的增量备份要添加--redo-only参数,到最后一次增量备份要去掉--redo-only)
3 对整体的完全备份进行恢复,回滚未提交的数据
模拟测试
测试完毕,恢复还是比较简单的。
看了以上mysql中XtraBackup备份讲义介绍,希望能给大家在实际运用中带来一定的帮助。本文由于篇幅有限,难免会有不足和需要补充的地方,大家可以继续关注创新互联行业资讯板块,会定期给大家更新行业新闻和知识,如有需要更加专业的解答,可在官网联系我们的24小时售前售后,随时帮您解答问题的。
另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。