xtrabackup全量备份和增(差)量备份

1.xtrabackup全量备份和恢复

1)备份:

	innobackupex --default-file=/PATH/TO/DEFAULT --host=ID ADDR --user=USER_NAME -P PASSWORD /PATH/TO/BACKUP
--default-file:指定备份时,从那个配置文件中读取配置信息。默认是使用的默认主配置文件,此时可以不写
--host:指定数据库服务ip地址。默认为localhost,此时可不写
--user:指定连接数据库服务的用户。默认为root,此时可不写
-p:指定用户密码
/PATH/TO/BACKUP:备份文件存放目录
注意:
completed OK!字样,有它才说明备份成功,innobackupex会把备份过程完整输出到屏幕。

2)备份目录文件:

	在你所指定的备份目录下可以找到以当前时间命令的备份文件
[root@localhost backup]#ls
2017-11-18_19-39-17
[root@localhost backup]#ll 2017-11-18_19-39-17/
total 18460
-rw-r----- 1 root root 417 Nov 18 19:39 backup-my.cnf
-rw-r----- 1 root root 18874368 Nov 18 19:39 ibdata1
drwxr-x--- 2 root root 4096 Nov 18 19:39 mysql/
drwxr-x--- 2 root root 4096 Nov 18 19:39 performance_schema/
drwxr-x--- 2 root root 78 Nov 18 19:39 Syslog/
-rw-r----- 1 root root 19 Nov 18 19:39 xtrabackup_binlog_info
-rw-r----- 1 root root 113 Nov 18 19:39 xtrabackup_checkpoints
-rw-r----- 1 root root 448 Nov 18 19:39 xtrabackup_info
-rw-r----- 1 root root 2560 Nov 18 19:39 xtrabackup_logfile 文件介绍:
backup-my.cnf:
此文件中包含my.cnf中的设置信息,只包含了备份时需要的信息。
ibdata1:
这是个innodb的共享表空间文件
xtrabackup_binlog_info:
此文件记录了备份开始时二进制日志文件的位置(position)
xtrabackup_checkpoints:
此文件记录此次备份属于那种类型的备份等信息
xtrabackup_info:
此文件记录了备份的概要信息
xtrabackup_logfile:
此文件记录了备份过程中的日志,在对数据进行prepare时需要通过日志将数据还原成一致的可用备份数据

3)查看备份情况:

	cat /backup/2017-11-18_19-39-17/xtrabackup_checkpoints
backup_type = full-backuped
from_lsn = 0
to_lsn = 1947282
last_lsn = 1947282
compact = 0
recover_binlog_info = 0

4)恢复:

	在需要还原的服务器上安装xtrabackup。
把备份的整个目录拷贝到需要还原的服务器上。
两个服务器上的mysql版本需要相同(不相同的没试过)
1》prepare:
innobackupex --apply-log /PATH/TO/BACKUP/dir-quan
--apply-log:将目录中的日志应用到备份数据中
--use-memory=N:默认为100M,若备份数据量大且有足够的空闲内存时,可以用来指定大小的内存来工作,单位可以使用G,M....。
注意:
completed OK!字样
2》开始恢复:
确保服务停止
systemctl stop mariadb
数据目录必须为空目录
rm -rf /PATH/TO/DATADIR/*
数据目录一般为/var/lib/mysql/
恢复
innobackupex --datadir=/PATH/TO/DATADIR/ --copy-back /PATH/TO/BACKUP/dir-quan
修改权限
chown -R mysql: /PATH/TO/DATADIR/
启动服务
systemctl start mariadb
注意:
实际还原时,最好将对应的配置文件也都还原,也就是把原服务器上的配置拷贝下,确保配置还是原来的。
上述恢复并没有进行时间点的还原,实际工作中,需要进行。

2.xtrabackup增(差)量备份及恢复

	全量备份是差量备份与增量备份的基础。
差量备份只能针对上一次全量备份。
增量备份可以针对上一次任务一种备份。
通俗地来说:所有增量备份加到一起就是差量备份了。
增量和差量备份都是针对innodb表来说的,对myisam表来说即使执行了增量备份,其实也是全量备份。
注意:以下常说成增量,大家注意增量和差量间的区别就行。

1)增(差)量备份:

	innobackupex -pPASSWORD --incremental /PATH/TO/BACKUP --incremental-basedir=/PATH/TO/BACKUP/last-backup-file
--incremental /PATH/TO/BACKUP:表示本次备份是一个增量备份(若针对的上次备份为一个全量备份,这里也可以认为是个差量备份)
--incremental-basedir=/PATH/TO/BACKUP/last-backup-file:指定本次增量备份针对的是那个备份(可以是上个增量,也可以是上个全量)

2)查看备份情况:

	cat /backup/2017-11-20_03-43-15/xtrabackup_checkpoints
backup_type = incremental
from_lsn = 1947282
to_lsn = 2073366
last_lsn = 2073366
compact = 0
recover_binlog_info = 0
cat /backup/2017-11-20_03-51-32/xtrabackup_checkpoints
backup_type = incremental
from_lsn = 2073366
to_lsn = 2084330
last_lsn = 2084330
compact = 0
recover_binlog_info = 0

3)恢复:

	在需要还原的服务器上安装xtrabackup。
把备份的整个目录拷贝到需要还原的服务器上。
两个服务器上的mysql版本需要相同。
1》prepare:
对全量备份做准备工作
innobackupex --apply-log --redo-only /PATH/TO/BACKUP/dir-quan
--redo-only:表示进行准备(应用日志)工作时,只进行redo操作,只会重做已提交但未应用的事务,不会回滚未提交的事务。原因是后面还有个增量备份,未提交的可能在后面增量备份时进行提交。
对增(差)量备份做准备工作
innobackupex --apply-log [--redo-only] /PATH/TO/BACKUP/dir-quan --incremental-dir= /PATH/TO/BACKUP/dir-zeng
--redo-only:若只有一个增量备份或是最后那个增量备份文件,那么不需要这个选项,原因同上。也就是说这个选项不能用于最后一个增量备份进行prepare。
--incremental-dir=:此选项对应的目录为增量备份文件的目录
查看prepare情况
若不是对最后一个增量备份进行prepare,那么查看全量备份文件中的xtrabackup_checkpoints,可看到log-applied,LSN有所变化,可以和增量备份对比下。
cat /backup/2017-11-18_19-39-17/xtrabackup_checkpoints
backup_type = log-applied
from_lsn = 0
to_lsn = 2073366
last_lsn = 2073366
compact = 0
recover_binlog_info = 0
若是以及对最后一个增量备份进行了prepare,那么查看全量备份文件中的xtrabackup_checkpoints,可看到full-prepared,LSN有所变化
cat /backup/2017-11-18_19-39-17/xtrabackup_checkpoints
backup_type = full-prepared
from_lsn = 0
to_lsn = 2084330
last_lsn = 2084330
compact = 0
recover_binlog_info = 0
注意:
prepared中可以使用--user-memory=选项来加快速度,前提是你有空闲的内存可用。
--redo-only这个选项需要多加注意,它不能用于最后那个增量备份的prepared,且必须用于其他增量备份的prepared。原因是后面还有增量备份的,未提交的可能在后面增量备份时进行提交。 2》开始恢复:
确保服务停止
systemctl stop mariadb
数据目录必须为空目录
rm -rf /PATH/TO/DATADIR/*
数据目录一般为/var/lib/mysql/
恢复
innobackupex --datadir=/PATH/TO/DATADIR/ --copy-back /PATH/TO/BACKUP/dir-quan
修改权限
chown -R mysql: /PATH/TO/DATADIR/
启动服务并查看是否恢复
systemctl start mariadb
注意:
实际还原时,最好将对应的配置文件也都还原,也就是把原服务器上的配置拷贝下,确保配置还是原来的。
上述恢复并没有进行时间点的还原,实际工作中,需要进行。

3.binlog备份和恢复

        上述都没有说有关时间点的恢复,这个时间点恢复是指当你全量备份或增量备份后,下次备份还没开始,数据库发生故障后的备份和恢复。
这个时间点恢复的备份和恢复是通过binlog实现的。
备份
mysqlbinlog -j 245 binlog-log.xxxxxxx > /PATH/TO/BINLOG.sql
恢复
登录数据库的恢复
mysql > soure /PATH/TO/BINLOG.sql
or
mysql -uroot -p < /PATH/TO/BINLOG.sql

xtrabackup全量备份和增(差)量备份的更多相关文章

  1. Jenkins持续部署-创建差量更新包

    目录 Jenkins持续部署-创建差量更新包 目录 前言 目的 详细流程 生成版本号 获取版本号 创建文件更新清单 压缩 获取上个版本的包 创建差量更新包 读取服务器Json配置 远程创建文件夹目录 ...

  2. Xtrabackup全量 增量备份详解

    xtrabackup是Percona公司CTO Vadim参与开发的一款基于InnoDB的在线热备工具,具有开源,免费,支持在线热备,备份恢复速度快,占用磁盘空间小等特点,并且支持不同情况下的多种备份 ...

  3. 15、xtrabackup 全量备份

    xtrabackup 全量备份与恢复 安装 yum install https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2. ...

  4. Xtrabackup全量备份与恢复mysql数据库

    一.Xtrabackup简单概述: Percona  Xtrabackup是开源免费的MySQL数据库热备份软件,它能对InnoDB和XtraDB存储引擎的数据库非阻塞地备份(对于MyISAM的备份同 ...

  5. mysqldump全量备份+mysqlbinlog二进制日志增量备份

    日常的数据备份及恢复测试,是DBA工作重中之重的事情,所以要做好备份及测试,日常的备份常见有mysqldump+binlog备份.xtrabackup+binlog备份,无论那一种,几乎都少不了对bi ...

  6. zabbix3.4 监控网卡流量设置差量

    自定义监控项的时候 看里面预设的监控网卡下载流量的key是 net.if.in[if,<mode>]这次可以监控流量了 但是添加监控项的时候 看网上别人的 都是可以设置数值是每秒的差量 出 ...

  7. 编写 Target 检测 MSBuild / dotnet build 此次编译是否是差量编译

    MSBuild 或 Roslyn 编译项目时均支持差量编译,毕竟为了性能.我在 每次都要重新编译?太慢!让跨平台的 MSBuild/dotnet build 的 Target 支持差量编译 一文中介绍 ...

  8. 每次都要重新编译?太慢!让跨平台的 MSBuild/dotnet build 的 Target 支持差量编译

    如果你干预到了项目的编译过程,可能就需要考虑到差量编译了.不然--当你的项目大起来的时候,就会感受到每次都重新编译时,每次重复调试的过程都要进行漫长等待时的绝望和无奈. 如果你正遭遇差量编译失效,每次 ...

  9. 如何用Percona XtraBackup进行MySQL从库的单表备份和恢复【转】

    前提 应该确定采用的是单表一个表空间,否则不支持单表的备份与恢复. 在配置文件里边的mysqld段加上 innodb_file_per_table = 1 环境说明: 主库:192.168.0.1 从 ...

随机推荐

  1. jq 中each的用法 (share)

    each的使用方法 在jQuery里有一个each方法,用起来非常的爽,不用再像原来那样写for循环,jQuery源码里自己也有很多用到each方法.其实jQuery里的each方法是通过js里的ca ...

  2. C#保留2位小数的做法

    第一 算法实现           保留两位的话,就用一个浮点型先乘以100,然后取整,取整完了之后,再乘以1.0,然后再除以100.          上面这种做法是保留n位,不会四舍五入的.因为这 ...

  3. Minfilter过滤框架

    Minfilter过滤框架 优势 与传统的Sfilter过滤驱动相比,有这样几个优势 1. Minfilter加载顺序更易控制,Sfilter加载是随意的,也就是说它在IO设备栈上的顺序是根据其创建的 ...

  4. redux入门指南

    前言:大概一个月没有写博客了,这两天正好是周末,就写点东西来梳理下之前几个月的所写与所得; 大概两个月前,学习了一下 redux ,还是一点难度的,花了我一天的时间来搞明白他, 但是都没怎么记录,今天 ...

  5. jqueryui sortable拖拽后保存位置

    jqueryUI sortable 可以用来进行页面拖拽布局,然而有一个小问题就是拖拽后如何保存状态. 工作中遇到了这个情况,遍把这个问题记了下来,具体思路是: 利用拖拽stop后利用   var a ...

  6. 【vue系列之三】从一个vue-pdf-shower,说说vue组件和npm包

    前言 从去年年初开始,自己便下决心要写一个vue系列的博客,但时至今日,才写系列的第三篇博客,想来甚是惭愧. 但是慢归慢,每一篇都要保证质量,以及要写出自己的心路历程,防止自己工作中填的坑再让读者走一 ...

  7. 【译】巧用CSS变量实现自动前缀

    转:https://www.h5jun.com/post/autoprefixing-with-css-variables-lea-verou.html 最近,当我在制作 markapp.io 这个小 ...

  8. Django--进阶--中间件的使用

    - 中间件是什么? 中间件是一个钩子框架,它们可以介入Django 的请求和响应处理过程.它是一个轻量级.底层的“插件”系统,用于在全局修改Django 的输入或输出. 每个中间件组件负责完成某个特定 ...

  9. for/in 循环遍历对象的属性

    for/in 语句循环遍历对象的属性. js中获取key得到某对象中相对应的value的方法:obj.key js中根据动态key得到某对象中相对应的value的方法有二: 一.var key = & ...

  10. Laravel ORM 数据model操作

    1.ORM操作需要创建对应的model         class User extends Eloquent   2.有两种方式使用数据操作对象            a. 使用new关键字创建对象 ...