• 欢迎访问显哥博客,本网站纯属学习技术,绝无商业用途,欢迎小伙伴们共同学习!研究技术!QQ:52249909 加我QQ
  • 世界75亿人,这么小的概率,能认识你,是我一生的幸运,不妨加个QQ接触一下:52249909 加我QQ

Xtrabackup全量备份和增量备份超详细全攻略【显哥出品,必为精品】

MySQL lixian 4年前 (2021-01-13) 4806次浏览 0个评论 扫描二维码
文章目录[隐藏]

安装Xtrabackup教程请转到:https://www.lixian.fun/4608.html

全量备份恢复

全库备份全库恢复

#全备
innobackupex --defaults-file=/etc/my.cnf --user=root --password=123456 /data/mysql

#删库并停止数据库
service mysqld stop

#备份mysql数据目录
mv /data/mysqldata /data/mysqldata_bak && mkdir /data/mysqldata

#日志包含了redo以及undo的操作,应用过程类似与mysql hang机后的recovery操作,完成后备份处于一致性状态
innobackupex --defaults-file=/etc/my.cnf --apply-log --user=root --password=123456 /data/mysql/2021-01-13_11-27-37

#从备份目录拷贝数据,索引,日志到my.cnf文件里规定的初始位置
innobackupex --defaults-file=/etc/my.cnf --copy-back --user=root --password=123456 /data/mysql/2021-01-13_11-27-37

#更改权限
chown -R mysql:mysql /data/mysqldata

#启动数据库,全备恢复数据搞定
service mysqld start

单库备份恢复

数据库备份目录:/data/mysql
数据库数据目录:/data/mysqldata
数据库安装目录:/usr/local/mysql

(1).单库备份
innobackupex --defaults-file=/etc/my.cnf --user=root --password=123456 --no-timestamp  --databases=lx /data/mysql/lx_sql
(2).恢复单库
--关闭数据库
service mysqld stop

--innobackupex prepare部分表空间
innobackupex --defaults-file=/etc/my.cnf --no-timestamp --apply-log  --export --user root --socket=/var/lib/mysql/mysql.sock /data/mysql/lx_sql

--恢复到一个新的数据库
mysql初始化
/usr/local/mysql/bin/mysqld --defaults-file=/etc/my.cnf --initialize-insecure --basedir=/usr/local/mysql --datadir=/data/mysqldata --user=mysql
关闭新的mysqld实例

恢复数据
cp -rf /data/mysql/lx_sql/* /data/mysqldata

修改权限
chown mysql:mysql /data/mysqldata

--开启数据库
service mysqld start
completed OK!

增量备份恢复

增量备份有两种方法:

第一种,总是针对basedir做增量,这个方式恢复起来就特别简单了,只需要将最后一次的增量备份合并到全量备份里,就可以恢复了。
第一种方法示例图:
总是将1月1日的全备作为basedir,所以FROM_LSN号总是5000。
Xtrabackup全量备份和增量备份超详细全攻略【显哥出品,必为精品】
第二种,总是针对上一次的增量,做增量备份。这个方式的恢复,就要逐一合并了,也就是我上述所说看起来有点复杂的增备思路。
总是把上一次(最近一次)的备份作为basedir。
第二种方法示例图:
Xtrabackup全量备份和增量备份超详细全攻略【显哥出品,必为精品】


注意:下面介绍的方法是针对第二种的。

先来一次全备,两次增备

#全备:
innobackupex --user=root --password=123456 --no-timestamp /data/mysql/full_`date +%Y-%m-%d_%H-%M-%S_%w`

#第一次增备:
innobackupex --user=root --password=123456 --no-timestamp --incremental-basedir=/data/mysql/full_2021-01-13_15-42-05_3 --incremental /data/mysql/incr_`date +%Y-%m-%d_%H-%M-%S_%w`

#第二次增备:
innobackupex --user=root --password=123456 --no-timestamp --incremental-basedir=/data/mysql/incr_2021-01-13_15-46-09_3  /data/mysql/incr_`date +%Y-%m-%d_%H-%M-%S_%w`

[root@slave ~]# ll /data/mysql
总用量 12
drwxr-xr-x. 8 root root 4096 1月  13 15:48 full_2021-01-13_15-42-05_3
drwxr-xr-x. 8 root root 4096 1月  13 15:46 incr_2021-01-13_15-46-09_3
drwxr-xr-x. 8 root root 4096 1月  13 15:46 incr_2021-01-13_15-46-47_3

prepare准备过程:
这就是增量备份最麻烦的地方,因为总共做了三次备份,所以先做三次prepare:

先对全备做prepare:

innobackupex --apply-log --redo-only /data/mysql/full_2021-01-13_15-42-05_3

然后接下来做第一次增量备份的prepare:

innobackupex --apply-log --redo-only /data/mysql/full_2021-01-13_15-42-05_3 --incremental-dir=/data/mysql/incr_2021-01-13_15-46-09_3

再对第二次的增量备份prepare:

注意,第二次的增备是最后一次,所以不需要加上–redo-only参数:

innobackupex --apply-log /data/mysql/full_2021-01-13_15-42-05_3 --incremental-dir=/data/mysql/incr_2021-01-13_15-46-47_3

最后将两次增量备份和全备做一次合并:

innobackupex --apply-log /data/mysql/full_2021-01-13_15-42-05_3

模仿误删库,删文件删库都可以

rm -rf /data/mysqldata/lx
或者drop databases;

恢复数据:

#停掉mysqld
service mysqld stop

#移除数据库目录
mv /data/mysqldata /data/mysqldata_bak

#恢复数据
innobackupex --defaults-file=/etc/my.cnf --copy-back /data/mysql/full_2021-01-13_15-42-05_3

#修改权限
chown mysql:mysql -R /data/mysqldata

#启动数据库,增备恢复数据搞定
service mysqld start

常用参数说明

--defaults-file
同xtrabackup的--defaults-file参数

--apply-log
在备份目录下,通过应用名称为xtrabackup_logfile的交易日志文件来准备备份。同时,创建新的交易日志。

--copy-back
做数据恢复时将备份数据文件拷贝到MySQL服务器的datadir ;

--remote-host=HOSTNAME
通过ssh将备份数据存储到进程服务器上;

--stream=[tar]
备 份文件输出格式, tar时使用tar4ibd , 该文件可在XtarBackup binary文件中获得.如果备份时有指定--stream=tar, 则tar4ibd文件所处目录一定要在$PATH中(因为使用的是tar4ibd去压缩, 在XtraBackup的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=#
指定数据库恢复时使用的内存大小,需要搭配--apply-log参数

--throttle=IOS
同xtrabackup的--throttle参数

--sleep=是给ibbackup使用的,指定每备份1M数据,过程停止拷贝多少毫秒,也是为了在备份时尽量减小对正常业务的影响,具体可以查看ibbackup的手册 ;

--compress[=LEVEL]
对备份数据迚行压缩,仅支持ibbackup,xtrabackup还没有实现;

--include=REGEXP
对 xtrabackup参数--tables的封装,也支持ibbackup。备份包含的库表,例如:--include="test.*",意思是要备份 test库中所有的表。如果需要全备份,则省略这个参数;如果需要备份test库下的2个表:test1和test2,则写 成:--include="test.test1|test.test2"。也可以使用通配符,如:--include="test.test*"。

--databases=LIST
列出需要备份的databases,如果没有指定该参数,所有包含MyISAM和InnoDB表的database都会被备份;

--uncompress
解压备份的数据文件,支持ibbackup,xtrabackup还没有实现该功能;

--slave-info,
当备份一个作为复制环境的服务器时,这个参数会自动将CHANGE MASTER语句写到备份中,在恢复备份后,不必执行CHANGE MASTER语句。

--socket=SOCKET
指定mysql.sock所在位置,以便备份进程登录mysql.

--compact
创建一个不包含第二索引(除了主键之外的索引)的备份

--incremental-basedir
以上一次全量或增量备份的路径,作为增量备份的基础。指定这个参数的同时,应该同样指定--incremental参数

--incremental
创建增量备份,当指定这个参数的时候,应该指定--incremental-lsn或--incremental-basedir参数,否则将会备份到--incremental-basedir路径

--incremental-dir=DIRECTORY
指定增量备份的目录,需要搭配--incremental参数。

--no-timestamp
这个参数会让xtrabackup在备份的时候不创建带有时间格式的子文件夹。当指定了这个参数,备份会直接创建在指定的备份目录下。
--tables-file=FILE

这个参数会接受一个字符串,这个字符串指定了一个文件,这个文件包含了要备份的表名,格式如database.table,一行一个。
 
--use-memory=# -apply-log 调节内存使用 

 --parallel=  多线程拷贝数据文件,使用该参数要考虑线上的数据库的压力的问题,如果线程开启较多,会对硬盘产生交大的压力。

本站博主 , 版权所有丨如未注明 , 均为原创
转载请注明原文链接:Xtrabackup全量备份和增量备份超详细全攻略【显哥出品,必为精品】
喜欢 (4)

您必须 登录 才能发表评论!