docker中使用xtrabackup对mysql的备份与恢复

安装 docker yum -y install docker
启动 docker service docker start
安装包含xtrabackup的docker镜像 docker pull registry.cn-hangzhou.aliyuncs.com/xiayu/mysql-5.6-xtrabackup
查看已安装docker镜像 docker images
加载该镜像 docker run -it ******(上一步查询出的docker镜像的ID) /bin/bash
全备 innobackupex --defaults-file=/etc/mysql/my.cnf(修改成本机my.cnf的绝对路径,所有路径都是我本地路径,使用需要修改)  --user='root' --password='root' /mysql_bak/full(备份文件的绝对路径,文件夹需提前创建好)




增量备份1   xtrabackup --defaults-file=/etc/mysql/my.cnf --backup --target-dir=/backup/xtrabackup/full/  --incremental-dir=/backup/xtrabackup/increm1
增量备份2   xtrabackup --defaults-file=/etc/mysql/my.cnf --backup --target-dir=/backup/xtrabackup/full/  --incremental-dir=/backup/xtrabackup/increm2
另外一种,就是备份增量备份1--2之间的数据 xtrabackup --defauls-file=/etc/mysql/my.cnf --backup --target-dir=/backup/xtrabackup/increm2 --incremental-basedir=/backup/xtrabackup/increm1




应用日志 innobackupex --defaults-file=/etc/mysql/my.cnf  --user='root' --apply-log --redo-only /mysql_bak/full/2017-07-31_01-36-18


将数据copy回去 innobackupex --defaults-file=/etc/mysql/my.cnf  --user='root' --copy-back /mysql_bak/full/2017-07-31_01-36-18
此处可能会报错,data文件夹不为空,清空文件夹 rm -rf /mysql/data/* 
设置文件夹权限 chmod -r 777 /mysql/data(没有权限无法启动mysql)


搜索文件(破docker包,ibdata1和my.cnf没有一个在正常位置的,先查找到所在位置会方便很多) find / -name ***

你可能感兴趣的:(docker中使用xtrabackup对mysql的备份与恢复)