简介

  备份mysql数据库一直是一个比较恶心的工作,主要就是备份的数据库比较大实在是慢。最近开始使用xtrabackup来备份数据库,速度上快了很多,尤其还原速度要快的多。下面我将从安装开始简要介绍一下如何使用xtrabackup来备份数据库。

定义:xtrabackup工具是percona公司用perl语言开发的在线物理热备份工具,由于是采取物理拷贝的方式来做的备份,所以速度非常快,几十G数据也才几分钟就搞定了,而它巧妙的利用了mysql特性做到了在线热备份,不用像以前做物理备份那样关闭数据库才行,直接在线就能完成整库或者是部分库的全量备份和增量备份.

优点:

(1)备份过程快速、可靠

(2)备份过程不会打断正在执行的事务

(3)能够基于压缩等功能节约磁盘空间和流量

(4)自动实现备份检验

(5)还原速度快
Xtrabackup有两个主要的工具:xtrabackup、innobackupex
(1)xtrabackup只能备份InnoDB和XtraDB两种引擎的数据表。
(2)innobackupex备份innodb和myisam两种引擎,但是myisam数据目前不支持增量。理论上就是再xtrabackup基础上封装了备份myisam的功能。

安装

  网上很多钟方式,这里我简单一种(下载二进制安装包)来部署。部署环境cetnos6.5,mysql5.7.24,xtrabackup版本为最新的2.4.9。直接解压即可。

  1.   下载&解压

    # wget https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.9/binary/tarball/percona-xtrabackup-2.4.9-Linux-x86_64.tar.gz# tar -xf percona-xtrabackup-2.4.9-Linux-x86_64.tar.gz
    

  2.   添加path环境变量
    echo "export PATH=$PATH:/XXX/bin >> /etc/profile

  3.   source 生效即可使用。

备份

备份主要分为两种模式一种是tar模式一种是xbstream模式。

其中xbstream模式可以不落盘直接发送到备份服务器,当数据库服务器磁盘不足时是一种不错的方式,当然速度稍慢。顾名思义,流模式由Percona XtraBackup支持,以特殊的tar或xbstream格式将备份发送到STDOUT,而不是将文件复制到备份目录。这种模式允许使用其他程序来过滤备份的输出,从而为备份的存储提供更大的灵活性。例如,通过将输出管道连接到压缩实用程序来实现压缩。流备份和使用Unix管道的好处之一是备份可以被自动加密。
innobackupex在子进程的日志流模式下启动xtrabackup,并将其日志重定向到一个临时文件。然后,它使用xbstream以特殊的xbstream格式将所有数据文件流到STDOUT(二进制)。在它将所有数据文件流化到STDOUT后,它将停止xtrabackup并将保存的日志文件流化。下面看一下实例代码:

xbstream实例:

将完整备份直接存储到一个文件中:

$ innobackupex --stream=xbstream /root/backup/ > /root/backup/backup.xbstream

流式压缩备份:

$ innobackupex --stream=xbstream --compress /root/backup/ > /root/backup/backup.xbstream

解压缩备份到/root/backup/目录:

$ xbstream -x <  backup.xbstream -C /root/backup/

压缩备份发送到另一台主机并解压:

$ innobackupex --compress --stream=xbstream /root/backup/ | ssh user@otherhost "xbstream -x -C /root/backup/"

tar实例:

将完整备份直接存储到tar存档中:

$ innobackupex --stream=tar /root/backup/ > /root/backup/out.tar

将tar存档发送到另一个主机:

$ innobackupex --stream=tar ./ | ssh user@destination \ "cat - > /data/backups/backup.tar"

注意

要提取Percona XtraBackup的存档,必须使用tar和-i选项:

$ tar -xizf backup.tar.gz

使用首选的压缩工具进行压缩:

$ innobackupex --stream=tar ./ | gzip - > backup.tar.gz
$ innobackupex --stream=tar ./ | bzip2 - > backup.tar.bz2

恢复数据

xtrabackup有一个xtrabackup --copy-back选项,可以将备份恢复到服务器的datadir:

$ xtrabackup --copy-back --target-dir=/data/backups/

它会将所有与数据相关的文件复制回服务器的datadir,由服务器的my.cnf配置文件决定。
复制数据后应检查文件权限。你可能需要用类似的方法来调整它们:

$ chown -R mysql:mysql /var/lib/mysql

复加密的备份

参数说明:

 1 --compress:该选项表示压缩innodb数据文件的备份。
 2 --compress-threads:该选项表示并行压缩worker线程的数量。
 3 --compress-chunk-size:该选项表示每个压缩线程worker buffer的大小,单位是字节,默认是64K。
 4 --encrypt:该选项表示通过ENCRYPTION_ALGORITHM的算法加密innodb数据文件的备份,目前支持的算法有ASE128,AES192,AES256。
 5 --encrypt-threads:该选项表示并行加密的worker线程数量。
 6 --encrypt-chunk-size:该选项表示每个加密线程worker buffer的大小,单位是字节,默认是64K。
 7 --encrypt-key:该选项使用合适长度加密key,因为会记录到命令行,所以不推荐使用。
 8 --encryption-key-file:该选项表示文件必须是一个简单二进制或者文本文件,加密key可通过以下命令行命令生成:openssl rand -base64 24。
 9 --include:该选项表示使用正则表达式匹配表的名字[db.tb],要求为其指定匹配要备份的表的完整名称,即databasename.tablename。
10 --user:该选项表示备份账号。
11 --password:该选项表示备份的密码。
12 --port:该选项表示备份数据库的端口。
13 --host:该选项表示备份数据库的地址。
14 --databases:该选项接受的参数为数据名,如果要指定多个数据库,彼此间需要以空格隔开;如:"xtra_test dba_test",同时,在指定某数据库时,也可以只指定其中的某张表。如:"mydatabase.mytable"。该选项对innodb引擎表无效,还是会备份所有innodb表。此外,此选项也可以接受一个文件为参数,文件中每一行为一个要备份的对象。
15 --tables-file:该选项表示指定含有表列表的文件,格式为database.table,该选项直接传给--tables-file。
16 --socket:该选项表示mysql.sock所在位置,以便备份进程登录mysql。
17 --no-timestamp:该选项可以表示不要创建一个时间戳目录来存储备份,指定到自己想要的备份文件夹。
18 --ibbackup:该选项指定了使用哪个xtrabackup二进制程序。IBBACKUP-BINARY是运行percona xtrabackup的命令。这个选项适用于xtrbackup二进制不在你是搜索和工作目录,如果指定了该选项,innoabackupex自动决定用的二进制程序。
19 --slave-info:该选项表示对slave进行备份的时候使用,打印出master的名字和binlog pos,同样将这些信息以change master的命令写入xtrabackup_slave_info文件。可以通过基于这份备份启动一个从库。
20 --safe-slave-backup:该选项表示为保证一致性复制状态,这个选项停止SQL线程并且等到show status中的slave_open_temp_tables为0的时候开始备份,如果没有打开临时表,bakcup会立刻开始,否则SQL线程启动或者关闭知道没有打开的临时表。如果slave_open_temp_tables在--safe-slave-backup-timeount(默认300秒)秒之后不为0,从库sql线程会在备份完成的时候重启。
21 --rsync:该选项表示通过rsync工具优化本地传输,当指定这个选项,innobackupex使用rsync拷贝非Innodb文件而替换cp,当有很多DB和表的时候会快很多,不能--stream一起使用。
22 --kill-long-queries-timeout:该选项表示从开始执行FLUSH TABLES WITH READ LOCK到kill掉阻塞它的这些查询之间等待的秒数。默认值为0,不会kill任何查询,使用这个选项xtrabackup需要有Process和super权限。
23 --kill-long-query-type:该选项表示kill的类型,默认是all,可选select。
24 --ftwrl-wait-threshold:该选项表示检测到长查询,单位是秒,表示长查询的阈值。
25 --ftwrl-wait-query-type:该选项表示获得全局锁之前允许那种查询完成,默认是ALL,可选update。
26 --galera-info:该选项表示生成了包含创建备份时候本地节点状态的文件xtrabackup_galera_info文件,该选项只适用于备份PXC。
27 --stream:该选项表示流式备份的格式,backup完成之后以指定格式到STDOUT,目前只支持tar和xbstream。
28 --defaults-file:该选项指定了从哪个文件读取MySQL配置,必须放在命令行第一个选项的位置。
29 --defaults-extra-file:该选项指定了在标准defaults-file之前从哪个额外的文件读取MySQL配置,必须在命令行的第一个选项的位置。一般用于存备份用户的用户名和密码的配置文件。
30 ----defaults-group:该选项表示从配置文件读取的组,innobakcupex多个实例部署时使用。
31 --no-lock:该选项表示关闭FTWRL的表锁,只有在所有表都是Innodb表并且不关心backup的binlog pos点,如果有任何DDL语句正在执行或者非InnoDB正在更新时(包括mysql库下的表),都不应该使用这个选项,后果是导致备份数据不一致,如果考虑备份因为获得锁失败,可以考虑--safe-slave-backup立刻停止复制线程。
32 --tmpdir:该选项表示指定--stream的时候,指定临时文件存在哪里,在streaming和拷贝到远程server之前,事务日志首先存在临时文件里。在 使用参数stream=tar备份的时候,你的xtrabackup_logfile可能会临时放在/tmp目录下,如果你备份的时候并发写入较大的话 xtrabackup_logfile可能会很大(5G+),很可能会撑满你的/tmp目录,可以通过参数--tmpdir指定目录来解决这个问题。
33 --history:该选项表示percona server 的备份历史记录在percona_schema.xtrabackup_history表。
34 --incremental:该选项表示创建一个增量备份,需要指定--incremental-basedir。
35 --incremental-basedir:该选项表示接受了一个字符串参数指定含有full backup的目录为增量备份的base目录,与--incremental同时使用。
36 --incremental-dir:该选项表示增量备份的目录。
37 --incremental-force-scan:该选项表示创建一份增量备份时,强制扫描所有增量备份中的数据页。
38 --incremental-lsn:该选项表示指定增量备份的LSN,与--incremental选项一起使用。
39 --incremental-history-name:该选项表示存储在PERCONA_SCHEMA.xtrabackup_history基于增量备份的历史记录的名字。Percona Xtrabackup搜索历史表查找最近(innodb_to_lsn)成功备份并且将to_lsn值作为增量备份启动出事lsn.与innobackupex--incremental-history-uuid互斥。如果没有检测到有效的lsn,xtrabackup会返回error。
40 --incremental-history-uuid:该选项表示存储在percona_schema.xtrabackup_history基于增量备份的特定历史记录的UUID。
41 --close-files:该选项表示关闭不再访问的文件句柄,当xtrabackup打开表空间通常并不关闭文件句柄目的是正确的处理DDL操作。如果表空间数量巨大,这是一种可以关闭不再访问的文件句柄的方法。使用该选项有风险,会有产生不一致备份的可能。
42 --compact:该选项表示创建一份没有辅助索引的紧凑的备份。
43 --throttle:该选项表示每秒IO操作的次数,只作用于bakcup阶段有效。apply-log和--copy-back不生效不要一起用。

总结

   本篇简单介绍了xtrabackup的部署和使用,当然还有很多地方比如增量备份还原以及各种参数的使用,将在以后进行深入说明。最后汇总一下 xtrabackup一些功能:

  • 在不暂停数据库的情况下创建热的InnoDB备份
  • 进行MySQL的增量备份
  • 将压缩的MySQL备份传输到另一台服务器
  • 在MySQL服务器之间移动表格
  • 轻松创建新的MySQL复制从站
  • 在不增加服务器负载的情况下备份MySQL

xtrabackup部署以及使用相关推荐

  1. MySQL备份与恢复——基于Xtrabackup物理备份恢复

    一.说明 Percona XtraBackup工具提供了一种在执行MySQL数据热备的方法.Percona XtraBackup是一个免费的.在线的.开源的.完整的数据库备份解决方案,适用于MySQL ...

  2. MySQL 案例实战--MySQL 数据库 之 温备份 热备份

    MySQL 数据库 之 温备份 & 热备份 前言 一.完全备份方案 二.增量备份方案 三.GTID 备份 四.mydumper 备份 五.LVM 快照备份 六.xtrabackup 备份 1. ...

  3. MySQL 多实例部署 xtrabackup备份与恢复

    MySQL 多实例部署 1.下载安装包 [root@localhost ~]# wget http://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7. ...

  4. mysql 多实例部署、xtrabackup下载与安装

    mysql 多实例部署 一. 二进制安装mysql 软件下载 下载网络源 curl -o /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyu ...

  5. 多实例部署、开机自启、xtrabackup备份与恢复

    多实例部署.开机自启.xtrabackup备份与恢复 一.MySQL多实例部署 1 下载二进制包 wget http://https://dev.mysql.com/get/Downloads/MyS ...

  6. MySQL数据库高可用集群搭建-PXC集群部署

    Percona XtraDB Cluster(下文简称PXC集群)提供了MySQL高可用的一种实现方法.集群是有节点组成的,推荐配置至少3个节点,但是也可以运行在2个节点上. PXC原理描述: 分布式 ...

  7. xtrabackup 使用说明(续)

    2019独角兽企业重金招聘Python工程师标准>>> 背景: 关于物理备份工具xtrabackup的一些说明可以先看之前写过的文章说明:xtrabackup 安装使用.现在xtra ...

  8. centos6.10中部署percona-mysql双实例的方法

    centos6.10中部署percona-mysql双实例的方法 数据库的同步关系:192.168.11.53(master) --> slave(192.168.10.189) --> ...

  9. MySQL高可用方案-PXC(Percona XtraDB Cluster)环境部署详解

    MySQL高可用方案-PXC(Percona XtraDB Cluster)环境部署详解 Percona XtraDB Cluster简称PXC.Percona Xtradb Cluster的实现是在 ...

最新文章

  1. 区块链共识算法:PoS即权益证明 DPoS委托授权的权益证明
  2. Exchange服务器系列课程之七--维护邮件服务器(二)
  3. IAR中断定义#pragma vector = P0INT_VECTOR __interrupt void P0_ISR(void)啥意思?
  4. 专访腾讯徐汉彬:日请求高达3.5亿+平台的架构设计及演变
  5. 华硕h410csm怎么开启_主板BIOS中的launch CSM选项灰色无法更改的解决方法
  6. (十三)Hibernate高级配置
  7. java中void_关于java中void的用法?
  8. html5干货,干货:详解HTML5中常见的五大全局属性
  9. ONVIF协议网络摄像机(IPC)客户端程序开发(8):获取设备基本信息
  10. Struts2学习第4天--拦截器
  11. Android开发里的自定义View的实现
  12. java war包是什么_War包是什么??
  13. java毕业设计水果网店管理系统mybatis+源码+调试部署+系统+数据库+lw
  14. 哪有没时间这回事-读后感
  15. 给华南x99打鸡血BIOS教程
  16. 外卖CPS小程序源码分享
  17. 计算机制造商logo,如何更改系统oem制造商logo等信息
  18. 常见程序(discuz,ecshop,shopex,dedecms等)重置破解管理密码
  19. 分享一下自己存的网站
  20. Asus Prime B360M-A+i5-8400+RX 570 黑苹果efi引导文件

热门文章

  1. 比较jquery中的after(),append(),appendTo()方法
  2. 【转】Android虚拟平台的编译和整合
  3. 【原】人生的程序公式
  4. 探秘Spring AOP(上)
  5. 如何使用JMeter自身代理录制APP测试脚本
  6. 微软sql服务器开机自启,使用 SQL Server 服务启动选项
  7. mysql标记上具有语法错误_ProgrammingError:(1064,'您的SQL语法有错误;请查看与MySQL服务器版本相对应的手册以获得正确的语法...
  8. c#用canny算子做边缘提取_干货 | 边缘检测
  9. .net mysql 工作流_一个适合于.NET Core的超轻量级工作流引擎:Workflow-Core
  10. 想成为前端工程师,那么在大学期间应该如何规划?