一、承上启下

1. MySQL安装


2. XtraBackup安装


二、全量备份

1. 备份

执行以下命令进行数据备份:

xtrabackup --user=bkpuser --password=bpkpassword --backup --target-dir=/data/backups/mysql/

如果不指定--user参数,xtrabackup将会假设数据库的用户为当前操作xtrabackup命令的系统用户。

其他参数:

a. -port: 数据库的端口号;

b. -socket: 使用socket来连接本地数据库;

c. -host: 数据库的host地址。

备份执行之后的预期输出如下:

xtrabackup备份docker数据库 xtrabackup备份命令_mysql

备份之后,target-dir中的文件如下:

xtrabackup备份docker数据库 xtrabackup备份命令_mysql_02

2. 恢复

数据恢复分为两个阶段,准备(Prepare)阶段和恢复阶段。

(1) 在数据恢复之前首先需要关闭MySQL实例:

sudo systemctl stop mysqld

(2) 清空datadir

数据恢复之前必须要清空MySQL的datadir目录:

mkdir /tmp/mysql
mv /var/lib/mysql/* /tmp/mysql/

(3) 准备阶段

准备阶段的目的是使备份文件达到某个时间点的数据一致性。

xtrabackup --prepare --target-dir=/data/backups/mysql

预期输出:

xtrabackup备份docker数据库 xtrabackup备份命令_mysql_03

注意:在xtrabackup执行准备的过程中,不要中断该操作,否则可能引起准备阶段产生的文件不可用的问题。

(4) 恢复阶段

执行如下命令将备份文件拷贝至MySQL的datadir目录中进行恢复:

xtrabackup --copy-back --target-dir=/data/backups/mysql

如果你不希望保留target-dir中的备份文件,可以执行如下命令将备份文件移动至MySQL的datadir目录中:

xtrabackup --move-back --target-dir=/data/backups/mysql

甚至,你可以使用rsync或者cp命令将相关文件复制到datadir目录中:

rsync -avrP /data/backups/mysql /var/lib/mysql/

(5) 设置datadir权限

此时,datadir中文件的Owner是上面执行数据恢复的用户,我们需要重置datadir的权限:

sudo chown -R mysql: /var/lib/mysql

或者

sudo chown -R mysql:mysql /var/lib/mysql

(6) 重启服务

sudo systemctl start mysqld

三、增量备份

1. 备份

(1) 全量备份

xtrabackup增量备份是在全量备份的基础上进行的,可以设置每周全量备份一次,每天增量备份一次,或者每天全量备份一次,每小时增量备份一次。

执行增量备份之后,xtrabackup会在target-dir中生成一个名为xtrabackup_checkpoints的文件,内容如下:

xtrabackup备份docker数据库 xtrabackup备份命令_mysql_04

其中的*_lsn则是增量备份的依据。每个InnoDB数据页(page)都包含一个LSN(Log sequence number),LSN是MySQL系统的版本号,当某个数据页的数据发生改变的时候它的LSN就会增量改变。

(2) 第一次增量备份

xtrabackup --backup --target-dir=/data/backups/mysql/inc1 --incremental-basedir=/data/backups/mysql

target-dir用于保存增量备份文件的目录,上面的命令执行之后/data/backups/mysql-inc目录下会存在*.delta的文件;

incremental-basedir是保存全量备份文件的目录。

此外,增量备份也会生成检查点文件xtrabackup_checkpoints:

xtrabackup备份docker数据库 xtrabackup备份命令_备份文件_05

from_lsn是全量备份中的to_lsn/last_lsn。

(3) 第二次增量备份

xtrabackup --backup --target-dir=/data/backups/mysql/inc2 --incremental-basedir=/data/backups/mysql/inc1

target-dir用于保存增量备份文件的目录;

incremental-basedir是保存上一次增量备份文件的目录。

xtrabackup_checkpoints文件:

xtrabackup备份docker数据库 xtrabackup备份命令_增量备份_06

to_lsn与last_lsn不同意味着在执行增量备份期间,正在运行的数据库有数据更新。

2. 恢复

与恢复全量备份一样,恢复增量备份同样需要两个阶段。

(1) 准备阶段

有三个目录的文件需要依次Prepare:

/data/backups/mysql
/data/backups/mysql/inc1
/data/backups/mysql/inc2

a. 准备全量backup

xtrabackup --prepare --apply-log-only --target-dir=/data/backups/mysql

--apply-log-only 会避免xtrabackup撤销(Roll back)未提交的事务,因为这些事务所涉及到的改动可能会在随后的增量backup中提交。

xtrabackup备份docker数据库 xtrabackup备份命令_增量备份_07

 这里的log sequence number将会与target-dir的to_lsn保持一致。

b. 准备第一份增量backup 

xtrabackup --prepare --apply-log-only --target-dir=/data/backups/mysql --incremental-dir=/data/backups/mysql/inc1

该命令行会将增量备份更新到全量备份。

期望的输出如下:

xtrabackup备份docker数据库 xtrabackup备份命令_mysql_08

c. 准备第二份增量backup 

xtrabackup --prepare --target-dir=/data/backups/mysql --incremental-dir=/data/backups/mysql/inc2

与第一次执行类似,该命令行会将增量备份更新到全量备份。

(2) 恢复阶段

数据恢复与全量部分相同,此处不再赘述。

四、备份压缩

1. 压缩

XtraBackup支持压缩和解压备份文件,方法是在执行备份命令的时候添加参数:

--compress

该命令需要安装qpress并启用tools,我们在上面安装部分已经提到。

2. 压缩算法

(1) quicklz,这是--compress参数的默认算法,例如:

xtrabackup --backup --compress --target-dir=/data/backups/mysql

(2) lz4,需要指定lz4压缩算法:

xtrabackup --backup --compress=lz4 --target-dir=/data/backups/mysql

(3) Zstandard (ZSTD)

xtrabackup --backup --compress=zstd --target-dir=/data/backups/mysql

3. 多线程压缩

多线程压缩可以通过--compress-threads参数来实现,如下:

xtrabackup --backup --compress --compress-threads=4 --target-dir=/data/compressed/

4. 解压

(1) 在执行Prepare之前,需要先对压缩文件进行解压,解压需要使用--decompress参数:

xtrabackup --decompress --target-dir=/data/compressed/

(2) 自动清除压缩包

解压完成之后,压缩包就没用了,但XtraBackup并不会自动的对已经解压,除非你在解压过程中带上--remove-original参数:

xtrabackup --decompress --remove-original --target-dir=/data/compressed/

(3) 解压完成之后就是执行数据恢复了,参考上文不再赘述。

五、流式备份

对于大型数据库,流式备份能更好的节约系统资源并且有更好的性能表现,它甚至支持直接将备份文件通过SSH发送到另一台备份服务器上。

上文展示的XtraBackup的普通备份模式是将备份文件写入到命令参数中的target-dir中,而XtraBackup的流式备份模式将备份文件以xbstream的格式输出到标准输出流中。

关于Stream的具体用法可参考https://docs.percona.com/percona-xtrabackup/8.0/howtos/recipes_xbk_stream.html

六、参考

1. 官方

https://docs.percona.com/percona-xtrabackup/8.0/backup_scenarios/full_backup.html

2. 其他

https://www.digitalocean.com/community/tutorials/how-to-create-hot-backups-of-mysql-databases-with-percona-xtrabackup-on-centos-7

https://www.digitalocean.com/community/tutorials/how-to-configure-mysql-backups-with-percona-xtrabackup-on-ubuntu-16-04

https://severalnines.com/blog/mysqldump-or-percona-xtrabackup-backup-strategies-mysql-galera-cluster/