mysql物理备份 xtrabackup

第1章 物理备份 xtrabackup (xbp)

percona公司研发的MySQL物理备份工具 使用perl语言开发的

公司官网: https://www.percona.com/downloads/Percona-XtraBackup-LATEST/

优点: 备份快 原生态支持增量备份 但是要注意版本 (8.0数据库不支持 需要xbp8.0版本)

1.1 安装

下载依赖包:

  wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo

  yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL libev

下载主体

  yum -y install percona-xtrabackup-24-2.4.4-1.el7.x86_64.rpm

rpm包官网下载

wget https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.12/binary/redhat/7/x86_64/percona-xtrabackup-24-2.4.12-1.el7.x86_64.rpm
数据包下载地址:

https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.4/binary/redhat/6/x86_64/percona-xtrabackup-24-2.4.4-1.el6.x86_64.rpm

安装后查看是否成功

innobackupex --version

  innobackupex version 2.4.4 Linux (x86_64) (revision id: df58cf2)#版本信息

1.2 xbk备份原理

1. 自动判断引擎类型

InnoDB

Non-InnoDB(不是innodb)

2. InnoDB表 实现热备功能备份

开始备份innoDB时,自动允许进程ckpt,将当前已经提交的事务数据,刷写到磁盘,会生成一个CKPT的LSN号.(当前脏页录入过redo的数据 刷写到磁盘数据库中)

拷贝innodb引擎数据库相关文件 redo(只会拷贝备份期间产生的新的redo),拷贝完成后会产生一个LAST_LSN (备份时刻redo的记录)

3. 非InnoDB 表

自动开启 FTWRL (flush tables with read lock) 全局锁

拷贝数据文件.完成后自动解锁.

1.3 xbp也会锁表

因为这个特性的原因 xbp在备份系统表的时候 (默认系统表不是innodb引擎) 会短暂的锁表

1.4 增量备份

会基于上一次备份的last_LSN 检查数据页的变化 然后备份走

1.5 innobackuoex 备份工具应用

  1. 编写mysql配置文件 添加一个[clinet] 加入sock文件
vim /etc/my.cnf

[clinet]

socket=/tmp/mysql.sock

因为默认xbp会读取MySQL的配置文件 但是不会识别指定sock文件选项 所以我们要手动指定一下

5.6 xbk 在innodb表备份恢复的流程

  1. xbk备份执行的瞬间,立即触发ckpt,已提交的数据脏页,从内存刷写到磁盘,并记录此时的LSN号
  2. 备份时,拷贝磁盘数据页,并且记录备份过程中产生的redo和undo一起拷贝走,也就是checkpoint LSN之后的日志
  3. 在恢复之前,模拟Innodb“自动故障恢复”的过程,将redo(前滚)与undo(回滚)进行应用
  4. 恢复过程是cp 备份到原来数据目录下

第2章 全备

XBP主要就是一个命令 实现了备份功能

innobackupex --user=root --password=123 /data/backup #将所有数据备份到指定目录

生产中备份姿势

innobackupex --user=root --password=123 --no-timestamp /data/backup/full_date +%F``

--no-timestamp 取消系统自定义备份名

2.1 全备后DBP添加文件介绍

xtrabackup_binlog_info # 备份时刻binlog日志的节点

xtrabackup_checkpoints # 记录备份信息

xtrabackup_info # 关于备份的其他信息

xtrabackup_logfile # 备份期间产生的的redo信息

[root@db full_2019-11-20]# cat xtrabackup_checkpoints

backup_type = full-prepared

from_lsn = 0 # 0代表所有变化都备份了

to_lsn = 166188857 # ckpt  LSN (脏页刷写磁盘后编码LSN号)

last_lsn = 166188866 # last LSN ( redo编码 5.7开始 二者相差9)

compact = 0

recover_binlog_info = 0

2.2 增量备份

(1)增量备份的方式,是基于上一次备份进行增量。

(2)增量备份无法单独恢复。必须基于全备进行恢复。

(3)恢复时 需要所有增量必须要按顺序合并到全备中。

推荐每周全备一次 每天增备

增量备份时会根据头一天的xtrabackup_checkpoints文件中的last_lsn数值进行备份

innobackupex --user=root --password=123 --no-timestamp --incremental --incremental-basedir=/data/backup/full_2019-11-20 /data/backup/inc1

--no-timestamp自定义备份文件名

--incremental

--incremental-basedir= 指定根据那个备份 进行增备

第3章 恢复数据

模拟项 模拟周三drop了个库 进行数据恢复

(1)删掉原来备份

略.

(2)全备(周日)

[root@db01 backup]# innobackupex --user=root --password --no-timestamp /backup/full >&/tmp/xbk_full.log

(3)模拟周一数据变化

db01 [(none)]>create database cs charset utf8;

db01 [(none)]>use cs

db01 [cs]>create table t1 (id int);

db01 [cs]>insert into t1 values(1),(2),(3);

db01 [cs]>commit;

(4)第一次增量备份(周一)

innobackupex --user=root --password=123  --no-timestamp --incremental --incremental-basedir=/backup/full /backup/inc1 &>/tmp/inc1.log

(5)模拟周二数据

db01 [cs]>create table t2 (id int);

db01 [cs]>insert into t2 values(1),(2),(3);

db01 [cs]>commit;

(6)周二增量

innobackupex --user=root --password=123  --no-timestamp --incremental --incremental-basedir=/backup/inc1 /backup/inc2 &>/tmp/inc2.log

(7)模拟周三数据变化

db01 [cs]>create table t3 (id int);

db01 [cs]>insert into t3 values(1),(2),(3);

db01 [cs]>commit;

db01 [cs]>drop database cs;

恢复思路:

  1. 挂出维护页,停止当天的自动备份脚本

  2. 检查备份:周日full+周一inc1+周二inc2,周三的完整二进制日志

3. 进行备份整理(细节),截取关键的二进制日志(从备份——误删除之前)

4. 测试库进行备份恢复及日志恢复

5. 应用进行测试无误,开启业务

6. 此次工作的总结

恢复流程

  1. 检查备份

1afe8136-601d-11e9-9022-000c2928f5dd:7-9 GTID

  1. 备份整理(apply-log)+合并备份(full+inc1+inc2)

(1) 全备的整理

[root@db01 one]#innobackupex --apply-log --redo-only /data/backup/full

(2) 合并inc1到full中

[root@db01 one]#innobackupex --apply-log --redo-only --incremental-dir=/data/backup/inc1 /data/backup/full

(3) 合并inc2到full中

[root@db01 one]# innobackupex --apply-log --incremental-dir=/data/backup/inc2 /data/backup/full

(4) 最后一次整理全备

[root@db01 backup]#innobackupex --apply-log /data/backup/full

  1. 截取周二 23:00 到drop 之前的 binlog

[root@db01 inc2]# mysqlbinlog --skip-gtids --include-gtids='1afe8136-601d-11e9-9022-000c2928f5dd:7-9' /data/binlog/mysql-bin.000009 >/data/backup/binlog.sql

  1. 进行恢复

[root@db01 backup]# mkdir /data/mysql/data2 -p

[root@db01 full]# cp -a * /data/mysql/data2

[root@db01 backup]#chown -R mysql. /data/*

[root@db01 backup]#systemctl stop mysqld

vim /etc/my.cnf

datadir=/data/mysql/data2

systemctl start mysqld

mysql中书写

Master [(none)]>set sql_log_bin=0;

Master [(none)]>source /data/backup/binlog.sql

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

推荐阅读更多精彩内容