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

[经验分享] 使用Xtrabackup来实现MySQL数据库的备份和恢复

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-6-24 08:54:15 | 显示全部楼层 |阅读模式
一.Xtrabackup概述:
    Xtrabackup是由percona提供的mysql数据库备份工具,支持在线热备份.据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具,同时也支持mariadb.下载Xtrabackup,需要下载相应数据库版本和相应系统的rpm包或源代码,个人认为,rpm包安装完全可以解决问题,就没必要用源码编译安装了.
    Xtrabackup有两个主要的工具:xtrabackup、innobackupex[个人推荐使用此方式]
  注解:
  (1).xtrabackup只能备份InnoDB和XtraDB 两种数据表
  (2).innobackupex则封装了xtrabackup,同时可以备份MyISAM数据表
  Innobackupex完整备份后生成了几个重要的文件:
    xtrabackup_binlog_info:记录当前最新的LOG Position
    xtrabackup_binlog_pos_innodb:innodb log postion
    xtrabackup_checkpoints: 存放备份的起始位置beginlsn和结束位置endlsn,增量备份需要这个lsn [增量备份可以在这里面看from和to两个值的变化]

二.Xtrabackup特点:
  (1)备份过程快速、可靠
  (2)备份过程不会打断正在执行的事务
  (3)能够基于压缩等功能节约磁盘空间和流量
  (4)自动实现备份检验
  (5)还原速度快

三.Xtrabackup的安装:
  percona官方网站:http://www.percona.com/downloads/  请到此网站下载对应数据库版本的源码包或RPM包
  [iyunv@client103 ~]# rpm -ivh percona-xtrabackup-20-2.0.8-587.rhel6.x86_64.rpm

四.innobackupex相关参数说明:
  注:xtrabackup命令只备份数据文件,并不备份数据表结构(.frm),所以使用xtrabackup恢复的时候,你必须有对应表结构文件(.frm),所以,个人推荐采用innobackupex命令 [此命令相当于冷备份,复制数据目录的索引,数据,结构文件,但会有短暂的锁表(时间依赖于MyISAM大小)]
参数说明如下:
  --defaults-file:指定my.cnf参数文件的位置[此配置文件里必须指定datadir]
  --apply-log:同xtrabackup的--prepare参数,一般情况下,在备份完成后,数据尚且不能用于恢复操作,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务。因此,此时数据 文件仍处理不一致状态。--apply-log的作用是通过回滚未提交的事务及同步已经提交的事务至数据文件使数据文件处于一致性状态。
  --copy-back:做数据恢复时将备份数据文件拷贝到MySQL服务器的datadir
  --remote-host=HOSTNAME: 通过ssh将备份数据存储到进程服务器上
  --stream=[tar]:备份文件输出格式, 该文件可在XtarBackup binary文件中获得. 在使用参数stream=tar备份的时候,你的xtrabackup_logfile可能会临时放在/tmp目录下,如果你备份的时候并发写入较大的话,xtrabackup_logfile可能会很大(5G+),很可能会撑满你的/tmp目录,可以通过参数--tmpdir指定目录来解决这个问题.
  --tmpdir=DIRECTORY:当有指定--remote-host or --stream时, 事务日志临时存储的目录, 默认采用MySQL配置文件中所指定的临时目录tmpdir
  --redo-only --apply-log:强制备份日志时只redo,跳过rollback,这在做增量备份时非常必要
  --use-memory=*:该参数在prepare的时候使用,控制prepare时innodb实例使用的内存
  --databases=LIST:列出需要备份的databases,如果没有指定该参数,所有包含MyISAM和InnoDB表的database都会被备份
  --slave-info:备份从库, 加上--slave-info备份目录下会多生成一个xtrabackup_slave_info 文件, 这里会保存主日志文件以及偏移, 文件内容类似于:CHANGE MASTER TO MASTER_LOG_FILE='', MASTER_LOG_POS=0
  --socket=SOCKET:指定mysql.sock所在位置,以便备份进程登录mysql.

五.使用innobackupex命令来实现数据库备份:
1.完全备份与恢复:
# 指定备份某一数据库
[iyunv@client103 ~]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306 --databases=a /tmp/backup/ >/tmp/backup/innoback.log 2>&1
# 备份所有的数据库
[iyunv@client103 backup]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306  /tmp/backup/ >/tmp/backup/innoback.log 2>&1
# 注:还原时,需要清空数据目录,所以建议备份的话,执行全库备份
# 备份完成后,应用日志,是备份的数据保持一致[ /tmp/backup/2014-01-11_14-46-21/:为备份存放的位置]
[iyunv@client103 ~]# innobackupex --apply-log /tmp/backup/2014-01-11_14-46-21/
# 利用刚才的备份进行数据库还原
[iyunv@client103 ~]# innobackupex --copy-back /tmp/backup/2014-01-11_14-46-21/
### 备份到远程机器上[这里的ssh的话,需要实现两边的key同步,不需要输入密码,否则无法实现,此方法一般应该不用,待检验] ###
[iyunv@client103 ~]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306  --databases=a --stream=tar /tmp/backup/ |ssh root@192.168.1.100 cat ">"/tmp/backup

2.增量备份与恢复:
# 全备
[iyunv@client103 ~]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306  /tmp/backup/ >/tmp/backup/innoback.log 2>&1
# 基于全备的增量备份
[iyunv@client103 ~]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306 --incremental --incremental-basedir=/tmp/backup/全备的文件名/ /tmp/backup/
# 基于增量备份的增量备份
[iyunv@client103 ~]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306 --incremental --incremental-basedir=/tmp/backup/增量备份的文件名/ /tmp/backup/
# 备份应用日志,保证数据一致
# 全备应用日志
[iyunv@client103 ~]# innobackupex  --apply-log /tmp/backup/2014-01-11_15-37-31/
# 第一次的增量备份应用日志,应用完日志后,将合并到全备上,恢复使用全备恢复
[iyunv@client103 ~]# innobackupex  --apply-log /tmp/backup/2014-01-11_15-37-31/ --incremental-dir=/tmp/backup/2014-01-11_15-45-06/
# 将第二次增量备份应用日志并合并到全备上
[iyunv@client103 ~]# innobackupex  --apply-log /tmp/backup/2014-01-11_15-37-31/ --incremental-dir=/tmp/backup/2014-01-11_15-46-33/
# 此时两次增量备份其实都合并到全备上了,恢复是只需要使用全备进行恢复就可以了
# 模拟数据故障[删除数据库的数据目录,执行如下命令还原]
[iyunv@client103 ~]# innobackupex --copy-back /tmp/backup/2014-01-11_15-37-31/
# 恢复后的数据默认权限是有问题的,所以需要修改数据目录权限,如下
[iyunv@client103 ~]# chown -R mysql:mysql /var/lib/mysql/
# 此时数据恢复完成,重启数据库服务,进行测试就可以了。大家自行测试,有问题留言反馈!

3.简述备份和恢复的步骤:
(1).备份:
  a.全备
  b.基于全备的多次增量备份
(2).恢复:
  a.全备
  b.基于全备的多次增量备份
  c.全备应用日志,保证数据一致
  d.合并多次增量备份到全备上
  e.利用全备恢复数据
  f.恢复完成后,修改数据目录的权限
  g.重启mysql服务

运维网声明 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.iyunv.com/thread-20968-1-1.html 上篇帖子: xtrabackup原理及实施 下篇帖子: Xtrabackup备份mysql实战(做从库全过程) 数据库
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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