在实际的生产环境中要保证线上的服务正常是非常重要的,所以在平时备份数据库一般都是在使用业务比较少的时候进行的,而在mysql中有默认的备份工具mysqldump,在一般的场景中备份都没有太大的问题,mysqldump这种古老的工具在备份时是把数据转化成sql的脚本,是一种逻辑备份方式,但是比较大的数据备份时或者需要做主从同步的时的备份时mysqldump的效率就变的十分低下了(长时间的锁表、占用大量的系统资源、备份大量数据时间长等等),所以在这些特殊的场景下mysqldump并时不是很好的选择,因此有人用perl写了一个专门用来备份innodb和myisam引擎的开源工具——xtrabackup,当然在在1.51版本后为了也能备份myisam引擎就进行再次的封装xtrabackup即innobackupex,当然innobackupex在备份myisam引擎时会添加只读锁的,需要注意的是该工具所用的是物理备份,所以适用于在MySQL的服务器端来进行备份,不适用于远程备份,除非使用流式备份。

   xtrabackup开源工具官网下载地址:https://www.percona.com/downloads/XtraBackup找到你适合的版本,尽量用最新的,当然官网也有提供rpm包,但是为了方便就下载了二进制包进行快速的部署安装:

[root@localhost src]# wget https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.5/\
> binary/tarball/percona-xtrabackup-2.4.5-Linux-x86_64.tar.gz
[root@localhost src]# tar -zxvf percona-xtrabackup-2.4.5-Linux-x86_64.tar.gz -C /usr/local/
#配置说明手册及环境变量
[root@localhost src]# vim /etc/man.conf
…略…
MANPATH /usr/local/percona-xtrabackup-2.4.5-Linux-x86_64/man
[root@localhost src]# vim /etc/profile.d/percona-xtrabackup.sh
export PATH=$PATH:/usr/local/percona-xtrabackup-2.4.5-Linux-x86_64/bin

innobackupex中常用的选项参数有:

--host=name:mysql的主机ip地址
--port=#:mysql的端口号
--user=name:mysql的用户名
--socket=name:mysql socket文件路径
--password=password :mysql的密码
--databases=name:指定mysql库
--defaults-file:指定读取默认的my.cnf的文件路径,默认是读取/etc/my.cnf
--incremental-basedir=name:指定完全备份的目录名,用于增量备份时指定全量备份路径用
--incremental=name:指定增量备份的目录名
--incremental-dir=name1:指向增量备份的目录名按第一次增量备份开始一直往后,如:--incremental-dir=name{1,2,3}以此类推.
--apply-log:回滚innodb的事务,个用于备份数据后直接恢复数据用的,改参数指定的路径内需要有备份文件
--redo-only:强制备份日志时只redo ,跳过rollback,做增量备份的时候必须要用
--copy-back:还原备份的操作
--include=name:备份包含的库表,例如:--include="mysql.*"备份mysql库的所有表
--slave-info:备份从库, 加上--slave-info备份目录下会多生成一个xtrabackup_slave_info 文件, 这里会保存主日志文件以及偏移, 
文件内容类似于:CHANGE MASTER TO MASTER_LOG_FILE='', MASTER_LOG_POS=0,用于制作从库时候用的
--safe-slave-backup:和slave-info 结合使用,发起备份的时候,会把SLAVE暂停,确保备份时没有临时表打开,保证一致性
--no-lock:备份时不锁表,如果mysql的session中有“FLUSH TABLES WITH READ LOCK;”也不锁定

基本上一般常见的场景中这些参数都够用了,当然如果有其他特殊的场景所用的参数选项可以在查看innobackupex --help或者是man innobackupex查看更多,其中如常用的全库备份到/data/innobackup目录例子如下:

[root@localhost ~]# innobackupex --defaults-file=/etc/my.cnf --host=127.0.0.1 --user=root --port=3306 --password=password /data/innobackup

增量备份:

[root@localhost ~]# innobackupex --defaults-file=/etc/my.cnf --host=127.0.0.1 --user=root --port=3306 --password=password incremental-basedir=/data/innobackup/2017-12-10_12-35-16 --incremental=/data/innobackup

在备份成功后会在全量备份的路径下添加一个新时间戳的目录,xtrabackup备份MySQL采用的是使用物理备份,其效率取决于系统的磁盘I\O,也可以做增量备份,但是需要注意的是innobackupex主要针对的是InnoDB这类支持事务的引擎,如果是MyISAM等引擎,则仍然是全备。在备份完成后会有如下结果就是备份完成:

xtrabackup.png

至于恢复也很简单:

innobackupex --defaults-file=/data/innobackup/2017-12-10_12-35-16/backup-my.cnf --apply-log /data/innobackup/2017-12-10_12-35-16

为避免MySQL版本问题,可以修改备份生成对的backup-my.cnf参数:

#innodb_fast_checksum
#innodb_page_size
#innodb_log_block_size
如下是必须要注释的配置
#innodb_log_checksum_algorithm=strict_crc32
#innodb_fast_checksum=false
#innodb_log_block_size=512
#redo_log_version=1

如果是本地有一个MySQL的实例了,只是想起另一个端口还原出备份,同理也是可以修改配置文件,无非就是在配置文件中添加修改如下:

server_id=2
basedir = /usr/local/mysql
datadir = /data/innobackup/2017-12-10_12-35-16
port = 3307
socket = /tmp/mysql_3307.sock

如下就是还原成功:

xtrabackup还原.png

[root@localhost innobackup]# chown -R mysql:mysql ./2017-12-10_12-35-16#修改属组
[root@localhost innobackup]# mysqld_safe --defaults-file=/data/innobackup/2017-12-10_12-35-16/backup-my.cnf --user=mysql --datadir=/data/innobackup/2017-12-10_12-35-16 &#启动MySQL

如果忘记密码。则可以通过在配置文件中的[mysqld]段中条件如下来跳过授权来修改密码:

skip-grant-tables

当然在percona-xtrabackup中还有提供其他的工具:

xbcrypt:用于加密或者解密数据库
xbstream:流式备份的支持
xbcloud、xbcloud_osenv:用于云上上传和下载的工具