实验环境

此次实验的环境如下

  • MySQL 8.0.19
  • Redhat 7.4
  • 操作系统账号:mysql
  • 数据库备份账号:backup

这节是对前面章节的总结,详细内容可看前面的内容

1. 数据库全备及恢复

1.1 对数据库进行全备

shell> xtrabackup  -S  /data/mysql/data/mysql.sock --user=backup --password=123456  --backup --target-dir=/data/mysql/backup/

1.2 对全备进行恢复

prepare阶段

xtrabackup --prepare --use-memory=1G  --target-dir=/data/mysql/backup/

restore阶段

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

更改文件权限(可选)

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

启动数据库

systemctl start mysqld

2. 增量备份及还原

2.1 增量备份

全备命令

shell> xtrabackup  -S  /data/mysql/data/mysql.sock --user=backup --password=123456  --backup --target-dir=/data/mysql/backup/base

第一次增量备份

xtrabackup  -S  /data/mysql/data/mysql.sock --user=backup --password=123456  --backup --target-dir=/data/backups/inc1 --incremental-basedir=/data/backups/base

第二次增量备份

xtrabackup  -S  /data/mysql/data/mysql.sock --user=backup --password=123456  --backup --target-dir=/data/backups/inc2 --incremental-basedir=/data/backups/inc1 

2.2 对增量备份进行还原

prepare阶段

xtrabackup --prepare --apply-log-only --use-memory=1G  --target-dir=/data/mysql/backup/base
xtrabackup --prepare --apply-log-only --use-memory=1G  --target-dir=/data/mysql/backup/base  --incremental-dir=/data/backups/inc1
xtrabackup --prepare  -use-memory=1G  --target-dir=/data/mysql/backup/base  --incremental-dir=/data/backups/inc2

restore阶段

xtrabackup --copy-back  --target-dir=/data/mysql/backup/base

更改文件属性(可选)

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

启动数据库

systemctl start mysqld

3. 其他的一些参数

3.1 压缩备份

我们可以使用--no-timestamp不创建日期命名的文件夹

xtrabackup   -S  /data/mysql/data/mysql.sock --user=backup --password=123456  --backup  --compress --compress-threads=4 --target-dir=/data/mysql/backup/

3.2 手动指定配置文件

xtrabackup默认会读取/etc/my.cnf文件中的datadir参数,可以使用--defaults-file手动指定

注意该参数必须是第一个参数

xtrabackup --defaults-file=/tmp/other-my.cnf  -S  /data/mysql/data/mysql.sock --user=backup --password=123456  --backup --target-dir=/data/mysql/backup/

4. 参考资料

本专题所有内容翻译子Percona XtraBackup的官方文档

可通过如下链接下载

http://www.zhaibibei.cn/mysql/xtrabackup8/tutorial1/

上一章