使用Xtrabackup来实现mysql数据库的备份和恢复

php中文网
发布: 2016-06-07 17:36:52
原创
1360人浏览过

更多博文请关注:没有伞的孩子必须努力奔跑(www.xuchanggang.cn)一.Xtrabackup概述:Xtrabackup是由percona提供的mysql数据库备份工具,支持在线热备份.据官方介

  [root@client103 ~]# rpm -ivh percona-xtrabackup-20-2.0.8-587.rhel6.x86_64.rpm


双轨制会员管理系统 v9.1
双轨制会员管理系统 v9.1

双轨制会员管理系统是一个以asp+access进行开发的双轨制直销系统源码,要求很低,容易维护。 后台路径:/admin 后台用户名和密码均为:admin 9.1版更新内容: 1、增加了操作余额前自动备份数据库,如果操作成功,则自动删除备份的数据库;如果操作有页面错误导致不成功,则会自动恢复到备份的数据库。这样运行过程中,即使是程序错误,也不用担心数据丢失了。 2、增加会员登录首

双轨制会员管理系统 v9.1 843
查看详情 双轨制会员管理系统 v9.1

四.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.完全备份与恢复:

# 指定备份某一数据库 [root@client103 ~]# innobackupex --user=root --password=kongzhong --defaults-file=/etc/my.cnf --port=3306 --databases=a /tmp/backup/ >/tmp/backup/innoback.log 2>&1 # 备份所有的数据库 [root@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/:为备份存放的位置] [root@client103 ~]# innobackupex --apply-log /tmp/backup/2014-01-11_14-46-21/ # 利用刚才的备份进行数据库还原 [root@client103 ~]# innobackupex --copy-back /tmp/backup/2014-01-11_14-46-21/ ### 备份到远程机器上[这里的ssh的话,需要实现两边的key同步,不需要输入密码,否则无法实现,此方法一般应该不用,待检验] ### [root@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.增量备份与恢复:

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


3.简述备份和恢复的步骤:

(1).备份:

   a.全备

   b.基于全备的多次增量备份

(2).恢复:

   a.全备

   b.基于全备的多次增量备份

   c.全备应用日志,保证数据一致

   d.合并多次增量备份到全备上

   e.利用全备恢复数据

   f.恢复完成后,修改数据目录的权限

   g.重启mysql服务

本文出自 “没有伞的孩子必须努力奔跑” 博客,请务必保留此出处

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号