xtrabackup备份还原MySQL数据库

发布时间 - 2026-01-11 02:01:41    点击率:

mysqldump 备份鉴于其自身的某些特性(锁表,本质上备份出来insert脚本或者文本,不支持差异备份),不太适合对实时性要求比较高的情况
Xtrabackup可以解决mysqldump存在的上述的一些问题,生产环境应用的也会更多一些。
本文简单测试一下Xtrabackup对MySQL数据库的备份还原操作。

本着先把功能先撸起来再深入细节的原则,粗略地实现了一个备份还原,并未深入细节。

网上有不少xtrabackup的文章,因为环境不一样,有些需要配置xtrabackup的配置文件,
但是我在xtrabackup 2.4.7版本下测试就需要需求任何配置文件。可能是每个版本都的细节上都不一样,因此参考资料的时候要注意版本和环境。

innobackupex 备份

xtrabackup和MySQL的版本如下

完整备份

复制代码 代码如下:innobackupex --defaults-file=/etc/my.cnf --user=root --password=root --socket=/var/lib/mysql/mysql.sock /data/backup

说明:

1.--defaults-file=/etc/my.cnf文件必须在最前面
2.--user=root --password=root,--use=***与 --password=*** 中间一定要有空格,

如截图,完整备份完成

如截图,完整备份会创建一个日期(年月日时分秒,yyyy-MM-dd_hh-mm-ss)命名的文件
完整备份出来的内存,实际上是对所备份的数据库的数据文件的copy加上备份时候产生的一些信息,比如xtrabackup_checkpoints就是当前完整备份的一些个信息,这个信息对差异备份非常重要。

  差异备份

  差异备份之所以能够做到差异,就是依赖于完整备份的,在完整备份的基础上进行完整备份之后的差异的备份。
  而如何确定完整的备份之后备份到哪里,就依赖于完整备份之后的xtrabackup_checkpoints这个文件的。
  innobackupex --defaults-file=/etc/my.cnf --user=root --password=root --socket=/var/lib/mysql/mysql.sock --incremental /data/backup --incremental-basedir=/data/backup/2017-06-22_13-40-29

如截图,差异备份完成

如果在进行差异备份的时候,指定的完整备份的文件错误或者是未指定完整备份文件,会发现xtrabackup提示找不到xtrabackup_checkpoints这个文件。

innobackupex 还原

  准备阶段

  1、恢复完整备份,也即完整备份应用(--apply-log)日志
    innobackupex --defaults-file=/etc/my.cnf --apply-log --redo-only --socket=/var/lib/mysql/mysql.sock /data/backup/2017-06-22_13-40-29

  2、分别将增量备份应用到完整备份
    innobackupex --defaults-file=/etc/my.cnf --apply-log --redo-only --socket=/var/lib/mysql/mysql.sock --incremental /data/backup/2017-06-22_13-40-29 --incremental-basedir=/data/backup/2017-06-22_13-41-48

  如果有多个差异备份,分别应用差异备份到完整备份。

  恢复阶段

  1、完成差异备份的全部应用到完整备份之后,将恢复后的差异备份copy到原数据目录
    默认情况下,如果数据路径下存在文件,则copy失败,需要清空数据文件路径下的文件。
    innobackupex --copy-back /data/backup/2017-06-22_13-40-29
    如截图,完成copy-back

  2、启动MySQL服务

  启动mysql服务,发现启动失败

看一下错误日志(启动错误信息),mysql5.7yum安装默认的errorlog位于/var/log/mysqld.log中,且默认不会滚动,意味着所有的错误信息都记录在这个文件中。

  数据文件还原之后,需要读数据文件路径授予可读写的权限
  这里直接授权数据文件路径777,chmod -R 777 /var/lib/mysql
  然后启动mysql服务,可以正常启动。

xtrabackupex才刚刚开始,留下一大堆问题,有时间再一个一个验证。

  1、怎么实现单个库(表)的备份与还原,毕竟实际环境中,因为每个库备份的频率和方式(备份方案)是不一样的?

  2、怎么用全备+差异备份然后结合二进制日志做基于时间点的方式还原?

  3、如何验证备份文件的有效性?

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# xtrabackup  # mysql  # 备份还原  # 安装使用Percona XtraBackup来备份恢复MySQL的教程  # MySQL中使用innobackupex、xtrabackup进行大数据的备份和还原教程  # 利用Xtrabackup工具备份及恢复(MySQL DBA的必备工具)  # 编写脚本令Xtrabackup对MySQL数据进行备份的教程  # mysql中xtrabackup全量备份/增量备份及恢复  # mysql xtrabackup 备份恢复实现分享  # MySQL数据xtrabackup物理备份的方式  # MySQL xtrabackup 物理备份原理解析  # 使用xtrabackup实现mysql备份  # MySQL使用Xtrabackup备份流程详解  # MySQL物理备份之Percona XtraBackup的实现示例  # 错误信息  # 配置文件  # 备份文件  # 我在  # 也会  # 在这个  # 多个  # 不太  # 基础上  # 找不到  # 较高  # 依赖于  # 要注意  # 或者是  # 不支持  # 刚开始  # 非常重要  # 看一下  # 上都  # 先把 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: iOS发送验证码倒计时应用  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  Python函数文档自动校验_规范解析【教程】  Linux后台任务运行方法_nohup与&使用技巧【技巧】  Laravel如何使用Blade组件和插槽?(Component代码示例)  EditPlus 正则表达式 实战(3)  Win11关机界面怎么改_Win11自定义关机画面设置【工具】  企业网站制作这些问题要关注  Laravel如何实现本地化和多语言支持?(i18n教程)  C++用Dijkstra(迪杰斯特拉)算法求最短路径  实例解析Array和String方法  如何快速上传建站程序避免常见错误?  Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全  Android GridView 滑动条设置一直显示状态(推荐)  南京网站制作费用,南京远驱官方网站?  Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】  如何在建站之星绑定自定义域名?  什么是javascript作用域_全局和局部作用域有什么区别?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  Laravel集合Collection怎么用_Laravel集合常用函数详解  HTML5建模怎么导出为FBX格式_FBX格式兼容性及导出步骤【指南】  EditPlus中的正则表达式实战(6)  如何用JavaScript实现文本编辑器_光标和选区怎么处理  大学网站设计制作软件有哪些,如何将网站制作成自己app?  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  微信公众帐号开发教程之图文消息全攻略  5种Android数据存储方式汇总  bing浏览器学术搜索入口_bing学术文献检索地址  Laravel Admin后台管理框架推荐_Laravel快速开发后台工具  如何选择PHP开源工具快速搭建网站?  如何构建满足综合性能需求的优质建站方案?  Laravel如何使用Blade模板引擎?(完整语法和示例)  Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】  原生JS获取元素集合的子元素宽度实例  Laravel如何实现数据库事务?(DB Facade示例)  Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件  HTML5空格和nbsp有啥关系_nbsp的作用及使用场景【说明】  Laravel如何使用Service Provider服务提供者_Laravel依赖注入与容器绑定【深度】  用yum安装MySQLdb模块的步骤方法  网页设计与网站制作内容,怎样注册网站?  Laravel如何使用Spatie Media Library_Laravel图片上传管理与缩略图生成【步骤】  七夕网站制作视频,七夕大促活动怎么报名?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  如何用花生壳三步快速搭建专属网站?  千库网官网入口推荐 千库网设计创意平台入口  Laravel怎么判断请求类型_Laravel Request isMethod用法  Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  Laravel如何集成第三方登录_Laravel Socialite实现微信QQ微博登录  如何在阿里云高效完成企业建站全流程?