前言:

  • 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参数说明

#innobackupex --help
innobackupex - Non-blocking backup tool for InnoDB, XtraDB and HailDB databases
NOTICE: ‘innobackupex’ is deprecated, please switch to ‘xtrabackup’

备份:

innobackupex [–compress] [–compress-threads=NUMBER-OF-THREADS] [–compress-chunk-size=CHUNK-SIZE]
[–encrypt=ENCRYPTION-ALGORITHM] [–encrypt-threads=NUMBER-OF-THREADS] [–encrypt-chunk-size=CHUNK-SIZE]
[–encrypt-key=LITERAL-ENCRYPTION-KEY] | [–encryption-key-file=MY.KEY]
[–include=REGEXP] [–user=NAME]
[–password=WORD] [–port=PORT] [–socket=SOCKET]
[–no-timestamp] [–ibbackup=IBBACKUP-BINARY]
[–slave-info] [–galera-info] [–stream=tar|xbstream]
[–defaults-file=MY.CNF] [–defaults-group=GROUP-NAME]
[–databases=LIST] [–no-lock]
[–tmpdir=DIRECTORY] [–tables-file=FILE]
[–history=NAME]
[–incremental] [–incremental-basedir]
[–incremental-dir] [–incremental-force-scan] [–incremental-lsn]
[–incremental-history-name=NAME] [–incremental-history-uuid=UUID]
[–close-files] [–compact]
BACKUP-ROOT-DIR

#常用参数

--user:该选项表示备份账号。
--password:该选项表示备份的密码。
--port:该选项表示备份数据库的端口。
--host:该选项表示备份数据库的地址。
--socket:该选项表示mysql.sock所在位置,以便备份进程登录mysql。
--defaults-file:该选项指定了从哪个文件读取MySQL配置,必须放在命令行第一个选项的位置。
--databases:该选项接受的参数为数据名,如果要指定多个数据库,彼此间需要以空格隔开;如:"db1 db2",同时,在指定某数据库时,也可以只指定其中的某张表。如:"mydatabase.mytable"。该选项对innodb引擎表无效,还是会备份所有innodb表。此外,此选项也可以接受一个文件为参数,文件中每一行为一个要备份的对象。

#压缩参数
–compress:该选项表示压缩innodb数据文件的备份。
–compress-threads:该选项表示并行压缩worker线程的数量。
–compress-chunk-size:该选项表示每个压缩线程worker buffer的大小,单位是字节,默认是64K。

#加密参数
–encrypt:该选项表示通过ENCRYPTION_ALGORITHM的算法加密innodb数据文件的备份,目前支持的算法有ASE128,AES192,AES256。
–encrypt-key:该选项使用合适长度加密key,因为会记录到命令行,所以不推荐使用。
–encryption-key-file:该选项表示文件必须是一个简单二进制或者文本文件,加密key可通过以下命令行命令生成:openssl rand -base64 24。
–encrypt-threads:该选项表示并行加密的worker线程数量。
–encrypt-chunk-size:该选项表示每个加密线程worker buffer的大小,单位是字节,默认是64K。

#增量备份参数
–incremental:该选项表示创建一个增量备份,需要指定–incremental-basedir。
–incremental-basedir:该选项表示接受了一个字符串参数指定含有full backup的目录为增量备份的base目录,与–incremental同时使用。
–incremental-lsn:该选项表示指定增量备份的LSN,与–incremental选项一起使用。
–incremental-dir:该选项表示增量备份的目录。
–incremental-force-scan:该选项表示创建一份增量备份时,强制扫描所有增量备份中的数据页。
–incremental-history-name:该选项表示存储在PERCONA_SCHEMA.xtrabackup_history基于增量备份的历史记录的名字。Percona Xtrabackup搜索历史表查找最近(innodb_to_lsn)成功备份并且将to_lsn值作为增量备份启动出事lsn.与innobackupex–incremental-history-uuid互斥。如果没有检测到有效的lsn,xtrabackup会返回error。
–incremental-history-uuid:该选项表示存储在percona_schema.xtrabackup_history基于增量备份的特定历史记录的UUID。

#主从
–slave-info:该选项表示对slave进行备份的时候使用,打印出master的名字和binlog pos,同样将这些信息以change master的命令写入xtrabackup_slave_info文件。可以通过基于这份备份启动一个从库。
–safe-slave-backup:该选项表示为保证一致性复制状态,这个选项停止SQL线程并且等到show status中的slave_open_temp_tables为0的时候开始备份,如果没有打开临时表,bakcup会立刻开始,否则SQL线程启动或者关闭知道没有打开的临时表。如果slave_open_temp_tables在–safe-slave-backup-timeount(默认300秒)秒之后不为0,从库sql线程会在备份完成的时候重启。

–include:该选项表示使用正则表达式匹配表的名字[db.tb],要求为其指定匹配要备份的表的完整名称,即databasename.tablename。
–tables-file:该选项表示指定含有表列表的文件,格式为database.table,该选项直接传给–tables-file。
–no-timestamp:该选项可以表示不要创建一个时间戳目录来存储备份,指定到自己想要的备份文件夹。
–rsync:该选项表示通过rsync工具优化本地传输,当指定这个选项,innobackupex使用rsync拷贝非Innodb文件而替换cp,当有很多DB和表的时候会快很多,不能–stream一起使用。
–stream:该选项表示流式备份的格式,backup完成之后以指定格式到STDOUT,目前只支持tar和xbstream。
–ibbackup:该选项指定了使用哪个xtrabackup二进制程序。IBBACKUP-BINARY是运行percona xtrabackup的命令。这个选项适用于xtrbackup二进制不在你是搜索和工作目录,如果指定了该选项,innoabackupex自动决定用的二进制程序。
–kill-long-queries-timeout:该选项表示从开始执行FLUSH TABLES WITH READ LOCK到kill掉阻塞它的这些查询之间等待的秒数。默认值为0,不会kill任何查询,使用这个选项xtrabackup需要有Process和super权限。
–kill-long-query-type:该选项表示kill的类型,默认是all,可选select。
–ftwrl-wait-threshold:该选项表示检测到长查询,单位是秒,表示长查询的阈值。
–ftwrl-wait-query-type:该选项表示获得全局锁之前允许那种查询完成,默认是ALL,可选update。
–galera-info:该选项表示生成了包含创建备份时候本地节点状态的文件xtrabackup_galera_info文件,该选项只适用于备份PXC。
–defaults-extra-file:该选项指定了在标准defaults-file之前从哪个额外的文件读取MySQL配置,必须在命令行的第一个选项的位置。一般用于存备份用户的用户名和密码的配置文件。
----defaults-group:该选项表示从配置文件读取的组,innobakcupex多个实例部署时使用。
–no-lock:该选项表示关闭FTWRL的表锁,只有在所有表都是Innodb表并且不关心backup的binlog pos点,如果有任何DDL语句正在执行或者非InnoDB正在更新时(包括mysql库下的表),都不应该使用这个选项,后果是导致备份数据不一致,如果考虑备份因为获得锁失败,可以考虑–safe-slave-backup立刻停止复制线程。
–tmpdir:该选项表示指定–stream的时候,指定临时文件存在哪里,在streaming和拷贝到远程server之前,事务日志首先存在临时文件里。在 使用参数stream=tar备份的时候,你的xtrabackup_logfile可能会临时放在/tmp目录下,如果你备份的时候并发写入较大的话 xtrabackup_logfile可能会很大(5G+),很可能会撑满你的/tmp目录,可以通过参数–tmpdir指定目录来解决这个问题。
–history:该选项表示percona server 的备份历史记录在percona_schema.xtrabackup_history表。 --close-files:该选项表示关闭不再访问的文件句柄,当xtrabackup打开表空间通常并不关闭文件句柄目的是正确的处理DDL操作。如果表空间数量巨大,这是一种可以关闭不再访问的文件句柄的方法。使用该选项有风险,会有产生不一致备份的可能。
–compact:该选项表示创建一份没有辅助索引的紧凑的备份。
–throttle:该选项表示每秒IO操作的次数,只作用于bakcup阶段有效。apply-log和–copy-back不生效不要一起用。

prepare:

innobackupex --apply-log [–use-memory=B]
[–defaults-file=MY.CNF]
[–export] [–redo-only] [–ibbackup=IBBACKUP-BINARY]
BACKUP-DIR

–apply-log:该选项表示同xtrabackup的–prepare参数,一般情况下,在备份完成后,数据尚且不能用于恢复操作,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务。因此,此时数据 文件仍处理不一致状态。–apply-log的作用是通过回滚未提交的事务及同步已经提交的事务至数据文件使数据文件处于一致性状态。
–use-memory:该选项表示和–apply-log选项一起使用,prepare 备份的时候,xtrabackup做crash recovery分配的内存大小,单位字节。也可(1MB,1M,1G,1GB),推荐1G。
–defaults-file:该选项指定了从哪个文件读取MySQL配置,必须放在命令行第一个选项的位置。
–export:这个选项表示开启可导出单独的表之后再导入其他Mysql中。
–redo-only:这个选项在prepare base full backup,往其中merge增量备份(但不包括最后一个)时候使用。

10
解压解密:

innobackupex [–decompress] [–decrypt=ENCRYPTION-ALGORITHM]
[–encrypt-key=LITERAL-ENCRYPTION-KEY] | [–encryption-key-file=MY.KEY]
[–parallel=NUMBER-OF-FORKS] BACKUP-DIR

–decompress:该选项表示解压–compress选项压缩的文件。
–parallel:该选项表示允许多个文件同时解压。为了解压,qpress工具必须有安装并且访问这个文件的权限。这个进程将在同一个位置移除原来的压缩/加密文件。
–decrypt:该选项表示解密通过–encrypt选项加密的.xbcrypt文件。

还原:

innobackupex --copy-back [–defaults-file=MY.CNF] [–defaults-group=GROUP-NAME] BACKUP-DIR
innobackupex --move-back [–defaults-file=MY.CNF] [–defaults-group=GROUP-NAME] BACKUP-DIR

–copy-back:做数据恢复时将备份数据文件拷贝到MySQL服务器的datadir。
–move-back:这个选项与–copy-back相似,唯一的区别是它不拷贝文件,而是移动文件到目的地。这个选项移除backup文件,用时候必须小心。使用场景:没有足够的磁盘空间同事保留数据文件和Backup副本

注意:
1.datadir目录必须为空。除非指定innobackupex --force-non-empty-directorires选项指定,否则–copy-backup选项不会覆盖
2.在restore之前,必须shutdown MySQL实例,你不能将一个运行中的实例restore到datadir目录中
3.由于文件属性会被保留,大部分情况下你需要在启动实例之前将文件的属主改为mysql,这些文件将属于创建备份的用户
chown -R my5711:mysql /data1/dbrestore
以上需要在用户调用Innobackupex之前完成
–force-non-empty-directories:指定该参数时候,使得innobackupex --copy-back或–move-back选项转移文件到非空目录,已存在的文件不会被覆盖。如果–copy-back和–move-back文件需要从备份目录拷贝一个在datadir已经存在的文件,会报错失败。

三、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_sizeinnodb_log_files_in_group

2.Undo日志

    记录事务的逆向逻辑操作或者逆向物理操作对应的数据变化的内容默认存放在共享表空间里面的(ibdata*文件)和Redo日志功能不同Undo日志主要用于回滚数据库崩溃前未完整提交的事务数据确保数据恢复前后一致

3.LSN

    全拼log Sequence Number意为日志序列号64位的整型数字用于记录Redo日志时,使用LSN唯一标识一条变化的数据

4.Checkpoint

    用来标识数据库崩溃后,应恢复的redo log的起始点

五、xtrabackup脑图

xtrabackup 命令详解相关推荐

  1. docker常用命令详解

    docker常用命令详解 本文只记录docker命令在大部分情境下的使用,如果想了解每一个选项的细节,请参考官方文档,这里只作为自己以后的备忘记录下来. 根据自己的理解,总的来说分为以下几种: Doc ...

  2. oracle home 命令,$ORACLE_HOMEbin目录下所有命令的使用方法及命令详解

    求$ORACLE_HOME/bin目录下所有命令的使用方法及命令详解 如题. $ORACLE_HOME/bin目录下有很多命令,那我们平时用到的也不是太多,即使用到的那部分可能用法也不是完全能掌握,所 ...

  3. 【FFmpeg】ffmpeg命令详解(三)高级选项

    ffmpeg命令详解(三)高级选项 1.-map 2.-ignore_unknown 3.-copy_unknown 4.-map_channel 5.-map_metadata 6.-map_cha ...

  4. 【FFmpeg】ffmpeg命令详解(二)

    ffmpeg命令详解(二) 4.流选择 4.1 自动选择流 4.2 手动选择流 5.命令行选择详解 5.1 命令行选项的值说明: 5.2 流说明符 5.3 通用选项 5.4 主选项 5.5 视频相关选 ...

  5. 【FFmpeg】ffmpeg命令详解(一)

    ffmpeg命令详解(一) 1.命令格式 2.简述 3.详细说明 3.1 过滤器 3.1.1 简单的过滤器图 3.1.2 复杂的过滤器图 3.2 流拷贝 1.命令格式 ffmpeg [global_o ...

  6. head和tail命令详解

    基础命令学习目录首页 原文链接:https://www.cnblogs.com/amosli/p/3496027.html 当要查看上千行的大文件时,我们可不会用cat命令把整个文件内容给打印出来,相 ...

  7. 常用memcached命令详解

    常用memcached命令详解: Memcached作为缓存服务器,对其操作的命令主要分为三类: 1.  服务器状态命令:可以查看memcahced服务的当前状态 2.  数据存储命令:如何存储数据到 ...

  8. linux yum命令详解

    yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器.基於RPM包管理,能够从指定的服务器自动下载RP ...

  9. linux中的shell有printf吗,Linux Shell系列教程之(八)Shell printf命令详解

    在上一篇:Linux Shell系列教程之(七)Shell输出这篇文章中,已经对Shell printf命令有了一个简略的介绍,本篇给大家详细介绍下Shell中的printf命令. 一.Shell p ...

最新文章

  1. java post 500_Post请求form-data格式时请求返回500的问题
  2. 策略模式,状态模式,监听模式之间的区分。
  3. 创业互联网公司如何搭建自己的技术框架
  4. ASP.NET Core 中文文档 第三章 原理(12)托管
  5. 加速静态内容访问速度的CDN
  6. 世界人口钟实时数据_全球人口将达80亿 2019年世界人口总数统计数据
  7. WinForm DataGridView新增加行
  8. 第5章 C++内存模型和原子类型操作
  9. Linux内核入门(六)—— __attribute_ 机制
  10. 计算机 高新 会计电算化,会计软件应用(用友软件系列)用友通T3试题汇编 , 会计电算化员级[电子资源]...
  11. ISIS协议的基础配置实验,原来做ISIS基础配置还可以这么有趣
  12. 垂直门户网站与SEO
  13. 河南理工计算机课程表,河南理工大学张威的课程表.doc
  14. Openssl 命令之cer证书转成pem. 利用ptf私钥文件生成公钥
  15. 语音信号处理——视频转换音频(FFmpeg)mp4转wav
  16. ON-LSTM:用有序神经元表达层次结构
  17. 7只老鼠找除100瓶水的有毒的水
  18. 笔记之Python网络数据采集
  19. 微软近日更新网页版Skype增通知版面和关键词搜寻
  20. 用迭代法求 x=根号a。求平方根的迭代公式为:X(n+1)=(Xn+a/Xn) /2。要求前后两次求出的x的差的绝对值 小于10的-5次方

热门文章

  1. cpout引脚是干什么的_A3936芯片引脚图
  2. 常见支持linux平台的应用软件
  3. Web端CAD图形找不同?一键在Web端找出CAD图不同并对比分析
  4. 广州市计算机应用能力考试地点,【广东】全国计算机等级考试考点查询(汇总)...
  5. SATA协议OOB随笔
  6. 二年级课程表(4月11日-4月15日)
  7. s-tui:在 Linux 中监控 CPU 温度、频率、功率和使用率的终端工具
  8. 在PHP中如何获取用户的真实IP
  9. RHCSA认证考试---5.配置 crontab
  10. dpi 、 dip 、分辨率、屏幕尺寸、px、density 关系以及换算(终结版)