
xtrabackup安装
发布日期:2021-05-09 07:05:28
浏览次数:18
分类:博客文章
本文共 8163 字,大约阅读时间需要 27 分钟。
一、物理备份Xtrabackup
#binlog不属于真正意义上的备份#Xtrabackup属于第三方工具
1.安装
#上传文件包[root@db03 ~]# rz percona-xtrabackup-24-2.4.4-1.el6.x86_64.rpm#下载epel源wget -O /etc/yum.repos.d/epel.repo https://mirrors.aliyun.com/repo/epel-6.repo#安装依赖(最好先安装依赖,再解压)yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL#下载Xtrabackupwget httpss://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#安装[root@db03 ~]# yum localinstall -y percona-xtrabackup-24-2.4.4-1.el6.x86_64.rpm#安装好后的命令[root@db03 ~]# xtrabackup[root@db03 ~]# innobackupex
2.Xtrabackup备份
1)对于非innodb表(比如myisam)是'直接锁表cp数据文件',属于一种'温备'。2)对于innodb的表(支持事务),'不锁表',cp数据页最终以数据文件方式保存下来,并且把redo(记录数据变化的过程)和undo(是否commit)一并备走,属于'热备'方式。3)备份时读取配置文件/etc/my.cnf(如果使用Xtrabackup备份,'必须'要配置datadir)#innodb存储引擎有支持事务,有redo undo的过程,所以,可以不锁表直接备份(热备),总之,支持事务就主持热备
3.Xtrabackup全量备份
1)准备备份目录
[root@db03 ~]# mkdir /backup
2)备份(全备)
[root@db03 ~]# innobackupex --user=root --password=123 /backup/full[root@db02 backup]# ll full/total 0drwxr-x--- 6 root root 212 Jul 23 15:15 2020-07-23_15-14-58#去掉时间戳进行备份[root@db03 ~]# innobackupex --user=root --password=123 --no-timestamp /backup/full--no-timestamp :去掉时间戳(为脚本中使用innobackupex时提供便利)使用xtrabackup软件备份,在配置文件中一定要指定datadirxtrabackuppex会自动锁表,备份好之后自动解锁使用innobackupex备份binlog后,binlog最好不要删除
3)查看全备内容
[root@db03 ~]# ll /backup/full/总用量 129052-rw-r----- 1 root root 434 7月 23 08:51 backup-my.cnf #配置文件drwxr-x--- 2 root root 68 7月 23 08:51 dump-rw-r----- 1 root root 79691776 7月 23 08:51 ibdata1 #共享表空间-rw-r----- 1 root root 52428800 7月 23 08:51 ibdata2drwxr-x--- 2 root root 4096 7月 23 08:51 mysqldrwxr-x--- 2 root root 4096 7月 23 08:51 performance_schemadrwxr-x--- 2 root root 68 7月 23 08:51 rowdrwxr-x--- 2 root root 20 7月 23 08:51 test-rw-r----- 1 root root 21 7月 23 08:51 xtrabackup_binlog_info #记录binlog的信息-rw-r----- 1 root root 113 7月 23 08:51 xtrabackup_checkpoints #记录备份的位置点-rw-r----- 1 root root 483 7月 23 08:51 xtrabackup_info #工具或数据的信息-rw-r----- 1 root root 2560 7月 23 08:51 xtrabackup_logfile #redo-log(二进制)#位置点[root@db03 full]# cat xtrabackup_checkpointsbackup_type = full-backupedfrom_lsn = 0to_lsn = 8417759[root@db02 backup]# ll /usr/local/mysql/data/total 112264-rw-rw---- 1 mysql mysql 56 Jul 23 04:50 auto.cnf #数据库唯一标识符UUID-rw-rw---- 1 mysql mysql 71925 Jul 23 11:45 db02.err #错误日志-rw-rw---- 1 mysql mysql 6 Jul 23 11:45 db02.pid-rw-rw---- 1 mysql mysql 12582912 Jul 23 11:45 ibdata1 #共享表空间(undolog也在这儿)-rw-rw---- 1 mysql mysql 50331648 Jul 23 11:45 ib_logfile0 #redo log-rw-rw---- 1 mysql mysql 50331648 Jul 23 04:50 ib_logfile1drwx------ 2 mysql mysql 4096 Jul 23 04:50 mysql-rw-rw---- 1 mysql mysql 69408 Jul 23 04:50 mysql-bin.000001-rw-rw---- 1 mysql mysql 1485584 Jul 23 04:50 mysql-bin.000002-rw-rw---- 1 mysql mysql 624 Jul 23 11:45 mysql-bin.indexsrwxrwxrwx 1 mysql mysql 0 Jul 23 11:45 mysql.socket #drwx------ 2 mysql mysql 4096 Jul 23 04:50 performance_schemadrwx------ 2 mysql mysql 6 Jul 23 04:50 test
4.Xtrabackup全备恢复数据
1)删除所有数据库
mysql> drop database dump;mysql> drop database performance_schema;mysql> drop database row;mysql> drop database test;
2)停止数据库
[root@db03 ~]# systemctl stop mysqld.service[root@db02 backup]# /etc/init.d/mysqld stopShutting down MySQL.. SUCCESS!#数据库停掉,数据将不能写入,这是可以避免的(配置mysql主从复制,延时从库,切换主机)(MHA也可以解决)
3)手动 模拟CSR的过程(必须做)
#将redo进行重做,已提交的写到数据文件,未提交的使用undo回滚,模拟CSR的过程,使用以下命令即可[root@db03 ~]# innobackupex --user=root --password=123 --apply-log /backup/full--apply-log :重做redo
4)恢复数据(全量恢复)
1>方法一:
#移走原数据目录[root@db03 mysql]# mv data data.back#将全备的数据目录迁移回来(redo undo过的)[root@db03 mysql]# cp -r /backup/full ./data[root@db03 mysql]# chown -R mysql.mysql data#启动数据库,查看数据[root@db02 mysql]# /etc/init.d/mysqld startStarting MySQL.Logging to '/usr/local/mysql/data/db02.err'.. SUCCESS! #在/backup/full 或者/data目录下修改目录或文件即修改了库或表
2>方法二:
#移走原数据目录[root@db03 mysql]# mv data data.back#使用innobackupex恢复数据(自带拷贝)[root@db03 mysql]# innobackupex --copy-back /backup/full/[root@db03 mysql]# chown -R mysql.mysql data#启动数据库,查看数据[root@db03 data]# systemctl start mysqld[root@db03 data]# mysql -uroot -p123mysql> show databases;#不授权的话,数据库都启动不了
5.Xtrabackup增量备份
1.基于上一次备份进行'增量'2.'增量备份'无法单独恢复,必须'基于全备'进行恢复3.所有增量'必须要按顺序'合并到全备当中#增量备份 差异备份,可以节约磁盘空间
1)先全备(innoDB存储引擎不用关闭数据库)
[root@db03 ~]# innobackupex --user=root --password=123 --no-timestamp /backup/full_$(date +%F)
2)写入新数据
[root@db03 ~]# mysql -uroot -p123mysql> use dumpmysql> insert dump values(10000),(20000),(30000);
3)第一次增备
[root@db01 ~]# innobackupex --user=root --password=123 --no-timestamp --incremental --incremental-basedir=/backup/full_2020-07-23 /backup/inc1参数说明:--no-timestamp:省略时间戳--incremental:开启增量备份功能--incremental-basedir:'上一次备份'的路径full_2020-07-23在前#验证[root@db03 ~]# cat /backup/full_2020-07-23/xtrabackup_checkpoints backup_type = full-preparedfrom_lsn = 0to_lsn = 8417759[root@db03 ~]# cat /backup/inc1/xtrabackup_checkpoints backup_type = incrementalfrom_lsn = 8417759to_lsn = 8419281
4)再次写入数据
[root@db03 ~]# mysql -uroot -p123mysql> use dumpmysql> insert dump values(100000),(200000),(300000);
5)第二次增备
[root@db03 ~]# innobackupex --user=root --password=123 --no-timestamp --incremental --incremental-basedir=/backup/inc1/ /backup/inc2#验证[root@db03 backup]# cat /backup/full_2020-07-23/xtrabackup_checkpoints backup_type = full-backupedfrom_lsn = 0to_lsn = 1636167[root@db03 backup]# cat /backup/inc1/xtrabackup_checkpoints backup_type = incrementalfrom_lsn = 1636167to_lsn = 1640828[root@db03 backup]# cat /backup/inc2/xtrabackup_checkpoints backup_type = incrementalfrom_lsn = 1640828to_lsn = 1645877
6)再次写入数据
7)第三次增量备份
[root@db03 backup]# innobackupex --user=root --no-timestamp --incremental --incremental-basedir=/backup/inc2 /backup/inc3
6.Xtrabackup增量恢复数据
mysql> show databases;+--------------------+| Database |+--------------------+| information_schema || dump || mysql || performance_schema || test || xs |+--------------------+mysql> drop database xs;[root@db02 backup]# /etc/init.d/mysqld stop
1)将全备执行redo
[root@db03 backup]# innobackupex --apply-log --redo-only /backup/full_2020-07-23#只有第一次全备需执行(--apply-log ),(相当于binlog里的begin和commit)#没有执行undo的数据将回滚
2)将第一次增备只执行redo并,合并到第一次全备
[root@db03 backup]# innobackupex --apply-log --redo-only --incremental-dir=/backup/inc1/ /backup/full_2020-07-23#验证[root@db03 backup]# cat /backup/full_2020-07-23/xtrabackup_checkpoints backup_type = log-appliedfrom_lsn = 0to_lsn = 1640828 #该值本来是inc1的位置点/inc1/'在前'通过查看/backup/full_2020-07-23/xtrabackup_checkpoints 中的位置点来判断合并的过程(语法错误需要重新执行合并语句)全量备份+增量备份,增量备份之前的数据将会有少量的丢失
3)将第二次增备只执行redo并合并到第一次全备
[root@db03 backup]# innobackupex --apply-log --redo-only --incremental-dir=/backup/inc2/ /backup/full_2020-07-23#验证[root@db03 backup]# cat /backup/full_2020-07-23/xtrabackup_checkpoints backup_type = log-appliedfrom_lsn = 0to_lsn = 1645877 #该值本来是inc2的位置点
4)将最后一次增备执行redo和undo并合并到第一次全备
[root@db03 backup]# innobackupex --apply-log --incremental-dir=/backup/inc3/ /backup/full_2020-07-23#验证[root@db03 backup]# [root@db03 backup]# cat /backup/full_2020-07-23/xtrabackup_checkpoints backup_type = full-preparedfrom_lsn = 0to_lsn = 1649869
5)将整体数据进行一次CSR
[root@db03 backup]# innobackupex --apply-log /backup/full_2020-07-23/[root@db02 backup]# cat full_2020-07-23/xtrabackup_checkpoints backup_type = full-preparedfrom_lsn = 0to_lsn = 1649869last_lsn = 1649869compact = 0recover_binlog_info = 0
6)恢复数据
[root@db03 mysql]# mv data data.bak[root@db03 mysql]# innobackupex --copy-back /backup/full_2020-07-23/[root@db03 mysql]# chown -R mysql.mysql data[root@db03 mysql]# systemctl start mysqldmysql> show databases;+--------------------+| Database |+--------------------+| information_schema || dump || mysql || performance_schema || test || xs | #数据恢复+--------------------+
7.总结
1.增备: 优点:占用磁盘空间小,没有重复数据 缺点:恢复麻烦 2.全备: 优点:恢复只需一次 缺点:占用磁盘空间,每次全备都有重复数据
思考
企业级增量恢复实战背景:某大型网站,mysql数据库,数据量500G,每日更新量100M-200M备份策略:xtrabackup,每周六0:00进行全备,周一到周五及周日00:00进行增量备份。故障场景:周三下午2点出现数据库意外删除表操作。
发表评论
最新留言
网站不错 人气很旺了 加油
[***.192.178.218]2025年04月09日 08时32分44秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
说说字库和字模的故事,然后在 MaixPy 里实现打印中文字体(任意字体)吧!
2019-03-06
centos7一步一步搭建docker jenkins 及自定义访问路径重点讲解
2019-03-06
最通俗易懂的囚徒困境
2019-03-06
liteide错误: 进程无法启动--解决方法
2019-03-06
Java程序中的代理作用和应用场景及实现
2019-03-06
Java 前台后台数据传递、中文乱码解决方法
2019-03-06
Git报错:Permission denied (publickey)
2019-03-06
常见的图文布局
2019-03-06
Laravel - 上手实现 - 文件上传、保存到 public 目录下
2019-03-06
将mongo设置为windows的服务
2019-03-06
【Flink】Flink 底层RPC框架分析
2019-03-06
【集合框架】JDK1.8源码分析之LinkedList(七)
2019-03-06
第七届C/C++B-方格填数 DFS
2019-03-06
数据结构课设--3哈夫曼编码译码系统(树应用)
2019-03-06
pku 1061 青蛙的约会 扩展欧几里得
2019-03-06
Spring Boot 2.4 配置文件将加载机制大变化
2019-03-06
也来玩玩 javascript对象深拷贝,浅拷贝
2019-03-06