本文将通过应用更为普遍的物理备份工具xtrabackup来演示数据备份及恢复的第二篇内容。

  1. xtrabackup 工具的安装1.1 安装依赖包

  

/xtrabackup的使用需要安装相关的依赖包否则使用过程中会报相关错误/yuminstall-yrsyncperllperl-Digest-MD5perlperl-devellibaiolibaio-develperl-Time-HiResperl-DBD-MySQL

  1.2 下载及安装

  去percona官网下载对应版本的安装包 , 因为每个版本对应的数据库版本不同,因此需要根据数据库的版本选择对应的xtrabackup的安装包.

  当前测试使用的数据库为MySQL5.7 因此下载2. 4 版本

  另外,2.4. 10 及以后版本中,对libgcrypt进行了区分,因此也需要查询自己服务器的libgcrypt版本,然后选择对应的安装包

  查看libgcrypt方法:

  

[root@testdb~]#yumlistinstalled|greplibgcrypt
libgcrypt.x86_641.5.3-14.el7@anaconda

  然后下载对应包

  

/二进制包/wgethttps://www.percona.com/downloads/Percona-XtraBackup-2.4/Percona-XtraBackup-2.4.18/binary/tarball/percona-xtrabackup-2.4.18-Linux-x86_64.libgcrypt153.tar.gz/rpm包/wgethttps://www.percona.com/downloads/Percona-XtraBackup-2.4/Percona-XtraBackup-2.4.18/binary/redhat/7/x86_64/Percona-XtraBackup-2.4.18-r29b4ca5-el7-x86_64-bundle.tar

  二进制包解压后即可使用,rpm包下载解压后 rpm -ivh 安装即可。操作均很简单,此处略过

  xtrabackup通常使用innobackupex命令, 可以使用 innobackupex --help 命令查看参数及说明。

  其中常用参数及说明如下:

  

--defaults-file待备份mysql实例的配置文件--user=USER备份用户,默认为当前系统用户,建议使用备份专用账号--password=PASSWD备份用户密码--port=PORT数据库端口,默认3306--host=HOST需备份数据库的IP--apply-log前滚、回滚日志,恢复前用--database指定需要备份的数据库,多个数据库之间以空格分开--copy-back将备份数据复制到目标路径--incremental增量备份,后面接的参数值为指定的增量备份的路径--incremental-basedir=DIRECTORY增量备份时使用指向上一次的增量备份所在的目录--incremental-dir=DIRECTORY增量备份还原的时候用来合并增量备份到全量,用来指定全备路径--redo-only对增量备份进行合并--rsync加快本地文件传输,适用于non-InnoDB数据库引擎。不与--stream共用--no-timestamp生成的备份文件不以时间戳为目录

  1.3 创建备份账号

  备份的账号建议单独创建,并授予相关权限

  

mysql>CREATEUSER'backup'@'localhost'IDENTIFIEDBY'Backup@123.com';
mysql>GRANTSUPER,RELOAD,LOCKTABLES,PROCESS,REPLICATIONCLIENTON.TO'backup'@'localhost';
mysql>FLUSHPRIVILEGES;

  2. 全量备份2.1 本地全量备份,不压缩

  后续会以此为基础进行增量备份

  

/创建备份结果的目录,此步骤也可以省略/mkdirall_backup/开始全量备份//root/xtrabackup/bin/innobackupex--defaults-file=/app/data/mysql3306/etc/my.cnf--socket=/app/data/mysql3306/tmp/mysql.sock--port=3306--user=backup--password='Backup@123.com'--no-timestampall_backup

  备份的结果存放在指定的目录 all_backup里,内容如下:

  注: 如果没有添加阻塞DDL操作的参数,备份过程中如有DDL操作,备份将终止。因此建议日常备份放在从库中进行。

  2.2 本地tar方式压缩备份

  有时为了考虑磁盘空间问题,会在备份的时候直接压缩用以节约磁盘空间或解决磁盘空间不足以存放全量非压缩文件的问题。

  

/gzip方式压缩//root/xtrabackup/bin/innobackupex--defaults-file=/app/data/mysql3306/etc/my.cnf--socket=/tmp/mysql.sock--port=3306--user=backup--password='Backup@123.com'--stream=tar/tmp|gzip>all_backup.tar.gz

  中间过程省略

  备份后的结果是一个压缩文件,经过对比,压缩后数据约为非压缩情况下的20%,压缩比还是比较高的。

  不过,压缩备份的方式速度相对较慢,且消耗CPU,该影响因素需要大家考虑到,视情况选择是否压缩。

  注意: 如果有单表过大 而/tmp路径空间不足的情况备份过程中可能会报错,因此可以指定其他空间较大的目录

  2.3 本地xbstream方式压缩备份

  gzip的压缩方式备份可能会有bug(案例可以自行寻找),出现如下错误:

  

xtrabackup:error:Thetransactionlogfileiscorrupted.
xtrabackup:error:ThelogwasnotappliedtotheintendedLSN!

  因此可以采用xbstream方式进行备份,备份命令如下:

  

/root/xtrabackup/bin/innobackupex--defaults-file=/app/data/mysql3306/etc/my.cnf--socket=/tmp/mysql.sock--port=3306--user=backup--password='Backup@123.com'/app/backup--tmpdir=/app/backup--stream=xbstream|gzip->all_backup.xbstream.gz

  xbstream压缩备份的过程和tar一致,就不再解释了。

  2.4 远程备份到其他机器

  远程备份与本地备份的相比 需要额外的配置远程主机的免密登录权限

  

/在备份所在用户的主机下配置连接目标主机的免密/ssh-keygenssh-copy-id-iuser@'target_ip'

  之后就可以将类似于本地备份的模式 将备份结果发送到远程机器

  

/root/xtrabackup/bin/innobackupex--defaults-file=/app/data/mysql3306/etc/my.cnf--socket=/tmp/mysql.sock--port=3306--user=backup--password='Backup@123.com'--stream=tar/tmp--no-timestamp|sshuser@'target_ip'"cat->/app/backup/remote_backup.tar"

  备份过程中可以在目标机器看到对应的备份文件,完成后如下

  注:

  3. 增量备份3.1 第一次增量备份

  可以先根据2. 1 的本地全备的基础上进行增量备份,首次增量备份脚本如下:

  

/root/xtrabackup/bin/innobackupex--defaults-file=/app/data/mysql3306/etc/my.cnf--socket=/tmp/mysql.sock--port=3306--user=backup--password='Backup@123.com'--incremental/app/backup/--incremental-basedir=/app/backup/all_backup

  此时,备份的结果放在/app/backup目录下,由于没指定no-timestamp参数,备份的结果存在在已三期时间命名的目录下:

  备份的过程和全量备份很相似,但是备份结果是不一样的

  结果如下

  注:增量备份仅能应用于InnoDB或XtraDB表等事务表,对于MyISAM表而言,执行增量备份时依旧进行全量备份

  3.2 第二次增量备份

  第二次增量备份是在第一次增量备份的基础上进行,因此incremental-basedir参数内容指定为上一次增量备份的目录即可

  

/root/xtrabackup/bin/innobackupex--defaults-file=/app/data/mysql3306/etc/my.cnf--socket=/tmp/mysql.sock--port=3306--user=backup--password='Backup@123.com'--incremental/app/backup/--incremental-basedir=/app/backup/2020-03-25_14-47-37

  完成后生成一个新的目录

  4. 恢复4.1 基于全量备份的恢复4.1.1 回放日志

  备份后的文件不能直接用作恢复,还需要先使用apply-log 做前滚和回滚

  

/root/xtrabackup/bin/innobackupex--defaults-file=./backup-my.cnf--apply-log/app/backup/all_backup

  注: 回放日志的时候 defaults-file 选择备份目录里的即可

  4.2.2 恢复至目标实例

  本次恢复至一个新实例中(如果恢复至现有的实例需要先关闭目标实例,删除数据目录及相关日志存储的目录。不建议直接恢复至现有实例 ,除非实际需要)

  

/创建新实例的相关目录/
mkdir-p/app/data/mysql3307/{data,logs,tmp,etc}/生产配置文件,本次直接拷贝其他实例的配置文件修改对应端口等/cp/app/data/mysql3306/etc/my.cnf/app/data/mysql3307/etc/sed-i"s#3306#3307#g"my.cnf/创建错误日志/touch/app/data/mysql3307/logs/mysqld.log

  然后拷贝至新实例中

  

/root/xtrabackup/bin/innobackupex--defaults-file=/app/data/mysql3307/etc/my.cnf--copy-back/app/backup/all_backup

  修改目标实例相关目录的权限

  

chown-Rmysql:mysql/app/data/mysql3307

  启动新实例即可

  

/usr/local/mysql5.7/bin/mysqld_safe--defaults-file=/app/data/mysql3307/etc/my.cnf&

  恢复完毕

  4.2 基于增量备份的恢复

  如果是基于第一次增量备份的恢复,操作如下

  

/使用合并增量备份的方式进行回放日志,先进行全量备份的合并//root/xtrabackup/bin/innobackupex--apply-log--redo-only/app/backup/all_backup/再合并第一次增量备份/
/root/xtrabackup/bin/innobackupex--apply-log--redo-only/app/backup/all_backup--incremental-dir=/app/backup/2020-03-25_14-47-37

  如果基于多次增量备份的恢复,则在全量备份及第一次增量备份的基础上继续合并后续的备份即可

  

/基于第二次增量备份的合并//root/xtrabackup/bin/innobackupex--apply-log--redo-only/app/backup/all_backup--incremental-dir=/app/backup/2020-03-25_15-06-28

  之后的操作和全量备份的恢复一样即可。

  5. 小结

  基于xtrabackup2. 4 版本备份MySQL5. 7 数据库的主要方法及过程常用情况均已演示,结尾处再总结一下xtrabackup的主要优点:

  本文只介绍了常用操作,还是有很多情况未做介绍,比如rds上的数据备份及还原等,请各位小伙伴自行探索,也可以与我讨论。

最后修改:2024 年 08 月 02 日
如果觉得我的文章对你有用,请随意赞赏