更多博文请关注:没有伞的孩子必须努力奔跑 (www.xuchanggang.cn)
一.Xtrabackup概述:
# 指定备份某一数据库 [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 [email protected] cat ">"/tmp/backup
# 全备 [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/ # 此时数据恢复完成,重启数据库服务,进行测试就可以了。大家自行测试,有问题留言反馈!