MySQL备份利器-xtrabackup的介绍和原理(附脑图)
标签(linux): mysql-xtrabackup
笔者Q:972581034 交流群:605799367。有任何疑问可与笔者或加群交流
xtrabackup是Percona公司针对mysql数据库开发的一款开源免费的物理备份(热备)工具
可针对InnoDB和XtraDB等事务引擎的数据库实现不锁表方式的备份
可针对MyISAM等非事务引擎的数据库实现不锁表方式的备份
一、xtrabackup的七大特点
1.直接拷贝物理文件,备份和恢复数据的速度非常快、安全可靠
2.在备份期间执行的事务不会间断,备份InnoDB数据不影响业务
3.备份期间不增加太多数据库的性能压力
4.支持对备份的数据自动校验
5.支持全量、增量、压缩备份及流备份
6.技持在线迁移表以及快速创建新的从库
7.支持几乎所有版本的MySQL和MariaDB
二、xtrabackup的备份原理及过程
第一步:
记录当前redo日志位置(即对应的LSN号)
第二步:
在后台启动一个进程持续监视redo日志文件的变化
第三步:
同时将变化的信息记录到xtrabackup_logfile中
第四步:
针对所有的innodb数据文件进行备份(复制)
第五步:
备份完成后执行“flush tables with read lock”,对数据库锁表
第六步:
备份(复制)MyISAM等非事务引擎的数据文件
第七步:
待InnoDB、MyISAM数据文件、redo日志备份完毕后,获取binlog二进制日志位置点信息
第八步:
执行unlock tables解锁命令,回复数据库可读写状态
三、innobackupex增量备份(仅对InnoDB引擎有效)
原理
拷贝备份之后的InnoDB中变更的“页”数据
拷贝时以全备中xtrabackup_checkpoints文件对应的LSN号为依据
将大于给定的LSN号的页数据(即增量数据)进行备份
因要比对全备LSN号,第一次增量是基于全备的,后每次增量基于上次增备
备份时发生了什么
第一步:
在全备的xtrabackup_checkpoints logfile中找到并记录最后一个checkoint(last checkpint LSN)
第二步:
从该LSN的位置拷贝InnoDB的redo日志到xtrabackup_logfile
第三步:
开始备份全部的数据文件:ibd
第四步:
待全部数据拷贝结束后,停止拷贝logfile
四、InnoDB日志
1.Redo日志
也称事务日志,是Innodb引擎重要组成部分
记录Innodb引擎中每个数据发生的变化信息
用于保证innodb数据的完整性,及丢数据后的恢复
可有效提升数据库的IO性能
配置参数为
innodb_log_file_size
innodb_log_files_in_group
2.Undo日志
记录事务的逆向逻辑操作或者逆向物理操作对应的数据变化的内容
默认存放在共享表空间里面的(ibdata*文件)
和Redo日志功能不同Undo日志主要用于回滚数据库崩溃前未完整提交的事务数据
确保数据恢复前后一致
3.LSN
全拼log Sequence Number
意为日志序列号
64位的整型数字
用于记录Redo日志时,使用LSN唯一标识一条变化的数据
4.Checkpoint
用来标识数据库崩溃后,应恢复的redo log的起始点
五、xtrabackup脑图
注:纯装X用。。

MySQL备份利器-xtrabackup的介绍和原理(附脑图)的更多相关文章
- mysql备份工具innobackupex,xtrabackup-2.1的原理和安装
mysql备份工具innobackupex,xtrabackup-2.1的原理和安装 http://bbs.2cto.com/read.php?tid=310496 一.Xtrabackup介绍 1. ...
- MySQL备份恢复之Xtrabackup
Preface Today,I'm gonna use the Xtrabackup tool to demonstrate the procedure of backing up MyS ...
- MySQL备份恢复工具Xtrabackup
参考文档https://www.cnblogs.com/youkanyouxiao/p/8335173.html Xtrabackup介绍 Xtrabackup是由percona开源的免费数据库热备 ...
- MySQL备份还原——mysqldump工具介绍
mysqldump是一款MySQL逻辑备份的工具,他将数据库里面的对象(表)导出成SQL脚本文件.有点类似于SQL SEVER的"任务-生成脚本"的逻辑备份功能.mysqldump ...
- mysql 备份软件 Xtrabackup 的 xtrabackup_binlog_pos_innodb和xtrabackup_binlog_info 文件区别
今天在操作 innobackupex 的时候,执行 change master to 的时候发现 xtrabackup_binlog_pos_innodb xtrabackup_binlog_i ...
- Mysql备份工具Xtrabackup
Xtrabackup是一个开源的免费的热备工具,在Xtrabackup包中主要有Xtrabackup和innobackupex两个工具.其中Xtrabackup只能备份InnoDB和XtraDB两种引 ...
- MySQL备份之XtraBackup工具使用
数据库的完整备份 [root@vhost1 ~]# innobackupex --defaults-file=/mysqldata/3306/my.cnf --user=root --passw ...
- mydumper linux mysql 备份利器
1 官网 https://launchpad.net/ 2 安装使用参考网站 http://www.cnblogs.com/digdeep/p/4925560.html
- mysql备份工具 :mysqldump mydumper Xtrabackup 原理
备份是数据安全的最后一道防线,对于任何数据丢失的场景,备份虽然不一定能恢复百分之百的数据(取决于备份周期),但至少能将损失降到最低.衡量备份恢复有两个重要的指标:恢复点目标(RPO)和恢复时间目标(R ...
随机推荐
- 有具体名称的匿名函数var bar = function foo(){}
http://kangax.github.io/nfe/ 命名的函数表达式 函数表达式实际上可以经常看到.Web开发中的一个常见模式是基于某种特性测试来"分叉"函数定义,从而获得最 ...
- 3DES加密
本文介绍了3DES加密特性,加密特点,3DES是对称加密,用一个密钥对内容进行加密,必须使用相同的密钥进行解密, 密钥必须配置,而且长度为24位,不足24位,用0位进行补全,本文也顺带介绍了其它加密算 ...
- spring boot +mysql + mybatis + druid的整理(一)——单数据源
一,使用spring boot脚手架搭建spring boot框架生成maven项目 如下图所示: 设置自定义的坐标,即左侧的Group和Artifact,右侧可以搜索添加一些依赖,搜索不到的可以在p ...
- Javascrip随笔1
isNaN:指示某个值不是数字 文本字符串中使用反斜杠对代码行进行换行; 在计算机程序中,经常会声明无值的变量.未使用值来声明的变量,其值实际上是 undefined.在执行过以下语句后,变量 car ...
- bzoj:3994:vijos1949: [SDOI2015]约数个数和
Description 设d(x)为x的约数个数,给定N.M,求 Input 输入文件包含多组测试数据. 第一行,一个整数T,表示测试数据的组数. 接下来的T行,每行两个整数N.M. O ...
- Codeforces__Raising Bacteria
题目传送门:Raising Bacteria //问题描述:一个盒子里面放一个细菌在一天可以增生两个细菌. 现在已知盒子里面细菌的个数,问你最初放多少个细菌可以增生盒子里面的细菌数量 //输入:盒子中 ...
- excel数据导出新妙招
之前在做项目的时候需要将数据库中的数据导出为excel表格一遍打印查阅,在网上找了很多插件也没有找到自己理想的好用的插件(也就是说没有找到令我满意的插件),最近在学习a标签的相关知识时理解到,a标签不 ...
- 1.移植3.4内核-分析内核启动过程,重新分区,烧写jffs2文件系统
1.在上章-移植uboot里.我们来分析下uboot是如何进入到内核的 首先,uboot启动内核是通过bootcmd命令行实现的,在我们之前移植的bootcmd命令行如下所示: bootcmd=nan ...
- Vue2反向代理
前一段时间写了一个vue2的小项目,用的是vue-cli脚手架搭建的项目,项目里需要跨域,但又不能使用jsonp,上网查了一下,发现有一个之前没接触过的词语--反向代理. 什么是"反向代 ...
- Maven中央仓库源地址改为阿里云(IDEA)
我的Maven是IDEA2017.1.2集成的,所以settings.xml在此位置 E:\Program Files\JetBrains\IntelliJ IDEA 2017.1.2\plugins ...