xtrabackup安装、使用与配置主从

关于 XtraBackup

XtraBackup 是一个对数据库做物理热备的备份工具,可用于InnoDB数据库的肺阻塞备份,对于MyISAM的备份需要加表锁。
XtraBackup 主要有两个命令脚本:xtrabackup和innobackupex
xtrabackup只能备份InnoDB和XtraDB两种数据表。
innobackupex则封装了xtrabackup,同时还可以备份MyISAM数据表。在高版本中xtrabackup实现了innobackupex的功能,innobackupex在8.0+版本中已被弃用

XtraBackup 安装

由于yum源中的XtraBackup版本较低不能备份高版本的mysql数据库,不建议使用yum安装XtraBackup。
下载地址 https://www.percona.com/downloads/XtraBackup/LATEST/ 根据自己的mysql版本选择对应的安装包。
我的mysql版本是5.7的这里我用的是2.4.9的版本。

wget https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.9/binary/redhat/7/x86_64/percona-xtrabackup-24-2.4.9-1.el7.x86_64.rpm
rpm -ivh percona-xtrabackup-24-2.4.9-1.el7.x86_64.rpm

如果安装失败可能是缺少对应的依赖包,yum install安装一下对应依赖包即可
如:yum install perl-DBD-MySQL.x86_64

innobackupex常用参数说明

innobackupex - Non-blocking backup tool for InnoDB, XtraDB and HailDB databases
innobackupex - 用于InnoDB、XtraDB和HailDB数据库的非阻塞备份工具

NOTICE: 'innobackupex' is deprecated, please switch to 'xtrabackup'
NOTICE: innobackupex'已被弃用,请使用'xtrabackup '

SYNOPOSIS

innobackupex [--compress] [--compress-threads=NUMBER-OF-THREADS] [--compress-chunk-size=CHUNK-SIZE]
             [--encrypt=ENCRYPTION-ALGORITHM] [--encrypt-threads=NUMBER-OF-THREADS] [--encrypt-chunk-size=CHUNK-SIZE]
             [--encrypt-key=LITERAL-ENCRYPTION-KEY] | [--encryption-key-file=MY.KEY]
             [--include=REGEXP] [--user=NAME]
             [--password=WORD] [--port=PORT] [--socket=SOCKET]
             [--no-timestamp] [--ibbackup=IBBACKUP-BINARY]
             [--slave-info] [--galera-info] [--stream=tar|xbstream]
             [--defaults-file=MY.CNF] [--defaults-group=GROUP-NAME]
             [--databases=LIST] [--no-lock]
             [--tmpdir=DIRECTORY] [--tables-file=FILE]
             [--history=NAME]
             [--incremental] [--incremental-basedir]
             [--incremental-dir] [--incremental-force-scan] [--incremental-lsn]
             [--incremental-history-name=NAME] [--incremental-history-uuid=UUID]
             [--close-files] [--compact]
             BACKUP-ROOT-DIR
此命令行对MySQL数据库进行热备份。默认情况下,它会在指定的备份目录中创建一个由当前日期和时间命名的子目录。使用——no-timestamp选项可以控制。此命令可以对所有数据库或使用——databases选项指定的所有数据库中的所有MyISAM和InnoDB表和索引进行完全备份。创建的备份包含.frm、. mrg、. myd、. myi、. mad、. mai、. trg、. trn、. arm、. arz、. csm、CSV、.opt、.par和InnoDB数据和日志文件。--defaults-file=my.cnf 文件定义了数据库的位置。这个命令会以mysql client程序连接到MySQL服务器,并作为子进程运行xtrabackup。

innobackupex --apply-log [--use-memory=B]
             [--defaults-file=MY.CNF]
             [--export] [--redo-only] [--ibbackup=IBBACKUP-BINARY]
             BACKUP-DIR
在上一个命令中生成的备份文件是不可以直接拿来用的。—apply-log命令会应用日志为使用这个备份做一个准备。这个会命令使用备份目录下的xtrabackup_logfile恢复backup-my.cnf中指定的InnoDB数据文件,并创建backup-my.cnf中指定的InnoDB日志文件。此命令作为子进程运行xtrabackup,但它不会连接到数据库服务器。

innobackupex --copy-back [--defaults-file=MY.CNF] [--defaults-group=GROUP-NAME] BACKUP-DIR

innobackupex --move-back [--defaults-file=MY.CNF] [--defaults-group=GROUP-NAME] BACKUP-DIR
—move-back命令与—copy-back类似,唯一的区别是它将文件移动而不是复制它们。由于此选项会删除备份文件,因此必须谨慎使用。当没有足够的空闲磁盘空间来复制文件时,它可能很有用。

innobackupex [--decompress] [--decrypt=ENCRYPTION-ALGORITHM]
             [--encrypt-key=LITERAL-ENCRYPTION-KEY] | [--encryption-key-file=MY.KEY]
             [--parallel=NUMBER-OF-FORKS] BACKUP-DIR
压缩和解压备份文件

* **--apply-log** 通过回滚未提交的事务及同步已经提交的事务至数据文件使数据文件处于一致性状态
* **--redo-only** 用于--apply-log,强制备份日志时只redo,跳过rollback,这在做增量备份时非常必要。
* **--incremental** 指明是增量备份,--incremental-basedir指定上次完整备份或者增量备份文件的位置。这里的增量备份其实只针对的是InnoDB,对于MyISAM来说,还是完整备份。
* **--no-lock** 使用此选项可禁用“LUSH TABLES WITH READ LOCK”的表锁定。如果此备份是用来做主从的不要使用此值。
* **--no-timestamp** 此选项可以禁止生成日期+时间的子目录
* **--databases** 指定备份的数据库,多个数据库用空格分隔
* **--close-files** 该选项表示关闭不再访问的文件句柄,当xtrabackup打开表空间通常并不关闭文件句柄目的是正确的处理DDL操作。如果表空间数量巨大,这是一种可以关闭不再访问的文件句柄的方法。使用该选项有风险,会有产生不一致备份的可能

示例

#备份数据库
xtrabackup --defaults-file=/usr/local/webserver/mysql-5.7/my.cnf --user=root --password='123456' --databases='online_core online_db_2' --backup --target-dir=/data/xtrabackup/dxk/ --socket=/tmp/mysql.sock
#应用日志
innobackupex --use-memory=1G --apply-log /data/xtrabackup/2019-01-07_18-14-01/
#恢复数据
innobackupex --defaults-file=/usr/local/webserver/mysql-5.7-baowei/my.cnf --move-back /data/xtrabackup/2019-01-07_18-14-01/

mysql主库不停机做主从配置

#全量备份主库
innobackupex --defaults-file=/usr/local/webserver/mysql-5.7/my.cnf --socket=/tmp/mysql.sock --user=root --password='123456' --parallel=4  /mnt/datadisk/xtrabackup/

#copy备份文件到从库主机
scp -r xtrabackup root@10.0.223.18:/mnt/datadisk/

#进入从库所在主机,停止从库,移除data目录
/usr/local/webserver/mysql-5.7-baowei/support-files/mysql.server stop
cd /mnt/datadisk
mv mysql_data_baowei mysql_data_baowei_bak

#应用日志
innobackupex --use-memory=1G --apply-log /mnt/datadisk/xtrabackup/2019-01-09_01-00-01/

#恢复数据到从库
innobackupex --defaults-file=/usr/local/webserver/mysql-5.7-baowei/my.cnf --move-back /mnt/datadisk/xtrabackup/xtrabackup/2019-01-09_01-00-01/

#修改从库data目录属主,启动从库
chown -R mysql:mysql /mnt/datadisk/mysql_data_baowei
/usr/local/webserver/mysql-5.7-baowei/support-files/mysql.server start

#主库创建slave账号
/usr/local/webserver/mysql-5.7/bin/mysql -u root -p
GRANT REPLICATION SLAVE ON  *.*  TO  'baoyuan_slave'@'10.0.223.18' IDENTIFIED BY '123456';
flush privileges;

#查看binlog位置,启动从库slave进程
cat /mnt/datadisk/xtrabackup/2019-01-09_01-00-01/xtrabackup_binlog_info
/usr/local/webserver/mysql-5.7-baowei/bin/mysql -u root -h 127.0.0.1 -P 3307 -p
CHANGE MASTER TO MASTER_HOST='10.0.223.17',MASTER_PORT=3306, MASTER_USER='baoyuan_slave',MASTER_PASSWORD='123456',MASTER_LOG_FILE='mysql-bin.000592',MASTER_LOG_POS=97895353;
start slave;
show slave status\G;

注意事项:

  • xtrabackup 8.0只能用于mysql8.0的版本,如果低版本mysql的备份和迁移需要用xtrabackup2.4版本。一定要注意看手册下载安装不同版本的xtrabackup。xtrabackup8及以上高版本没有innobackupex命令
  • 查看当前xtrabackup支持的mysql版本
[root@dzfxdb01 datadisk]# xtrabackup -v
xtrabackup version 2.4.9 based on MySQL server 5.7.13 Linux (x86_64) (revision id: a467167cdd4)

参考资料

https://www.cnblogs.com/zhoujinyi/p/5893333.html
https://www.jianshu.com/p/74b03a792ff8
https://blog.csdn.net/thundermeng/article/details/50448614

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,884评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,755评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,369评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,799评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,910评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,096评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,159评论 3 411
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,917评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,360评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,673评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,814评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,509评论 4 334
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,156评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,882评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,123评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,641评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,728评论 2 351

推荐阅读更多精彩内容