Xtrabackup
Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具InnoDB Hotbackup的一个很好的替代品。
Xtrabackup有两个主要的工具:xtrabackup、innobackupex
在xtrabackup的上一次整库备份基础上做增量备份(innodb only) 以流的形式产生备份,可以直接保存到远程机器上(本机硬盘空间不足时很有用)
1.下载&安装
yum安装
配置源
#vim /etc/yum.repos.d/percona.repo
[percona] name = CentOS $releasever - Percona baseurl=http://repo.percona.com/centos/$releasever/os/$basearch/ enabled = 1 gpgkey = file:///etc/pki/rpm-gpg/RPM-GPG-KEY-percona gpgcheck = 1
添加key
#cd /etc/pki/rpm-gpg
#wget http://www.percona.com/downloads/RPM-GPG-KEY-percona
yum安装xtrabackup
[root@server ~]# yum list |grep percona
Percona-SQL-50-debuginfo.i686 5.0.92-b23.85.rhel5 percona
Percona-SQL-client-50.i686 5.0.92-b23.85.rhel5 percona
Percona-SQL-devel-50.i686 5.0.92-b23.85.rhel5 percona
Percona-SQL-server-50.i686 5.0.92-b23.85.rhel5 percona
Percona-SQL-shared-50.i686 5.0.92-b23.85.rhel5 percona
Percona-SQL-shared-compat.i686 5.0.92-b23.85.rhel5 percona
Percona-SQL-test-50.i686 5.0.92-b23.85.rhel5 percona
Percona-Server-51-debuginfo.i686 5.1.59-rel13.0.325.rhel5 percona
Percona-Server-51-debuginfo.i386 5.1.61-rel13.2.430.rhel5 percona
Percona-Server-55-debuginfo.i686 5.5.20-rel24.1.217.rhel5 percona
Percona-Server-client-51.i686 5.1.59-rel13.0.325.rhel5 percona
Percona-Server-client-51.i386 5.1.61-rel13.2.430.rhel5 percona
Percona-Server-client-55.i686 5.5.20-rel24.1.217.rhel5 percona
Percona-Server-devel-51.i686 5.1.59-rel13.0.325.rhel5 percona
Percona-Server-devel-51.i386 5.1.61-rel13.2.430.rhel5 percona
Percona-Server-devel-55.i686 5.5.20-rel24.1.217.rhel5 percona
Percona-Server-server-51.i686 5.1.59-rel13.0.325.rhel5 percona
Percona-Server-server-51.i386 5.1.61-rel13.2.430.rhel5 percona
Percona-Server-server-55.i686 5.5.20-rel24.1.217.rhel5 percona
Percona-Server-shared-51.i686 5.1.59-rel13.0.325.rhel5 percona
Percona-Server-shared-51.i386 5.1.61-rel13.2.430.rhel5 percona
Percona-Server-shared-55.i686 5.5.20-rel24.1.217.rhel5 percona
Percona-Server-shared-compat.i386 5.1.61-rel13.2.430.rhel5 percona
Percona-Server-shared-compat.i686 5.5.20-rel24.1.217.rhel5 percona
Percona-Server-test-51.i686 5.1.59-rel13.0.325.rhel5 percona
Percona-Server-test-51.i386 5.1.61-rel13.2.430.rhel5 percona
Percona-Server-test-55.i686 5.5.20-rel24.1.217.rhel5 percona
percona-toolkit.noarch 2.0.3-1 percona
xtrabackup.i386 1.6.5-328.rhel5 percona
xtrabackup-debuginfo.i386 1.6.5-328.rhel5 percona
#yum install xtrabackup
rpm安装
安装依赖包
$ yum install cmake gcc gcc-c++ libaio libaio-devel automake autoconf bzr bison libtool ncurses5-devel
下载包&安装
#wget http://www.percona.com/downloads/XtraBackup/XtraBackup-1.6.5/RPM/rhel6/x86_64/xtrabackup-1.6.5-328.rhel6.x86_64.rpm
#rpm xtrabackup-1.6.5-328.rhel6.x86_64.rpm
2,使用
Usage: [./xtrabackup [DEFAULTS OPTION] —backup | ./xtrabackup [DEFAULTS OPTION] —prepare] [OPTIONS]
Default options are read from the following files in this order: /etc/my.cnf, /opt/mysql-5.0.xx/etc/my.cnf, ~/.my.cnf
参数说明:
--defaults-file= 读my.cnf的位置,在DB服务器上有多实例时很有用,未指定将读/etc/my.cnf~(如要备份DB 3307的数据库,要单独指定3307的 my.cnf文件)
--datadir= 数据存放目录,和my.cnf中要相一致~ (必须,但实际上一般不用特别指定,因为会从my.cnf中去读取~)
--target-dir= 存放备份文件的目录,要使用绝对路径~ 若此目录开始不存在,则--backup选项会建立此目录~
--backup 备份InnoDB/XTraDB表空间,存放*.ibd及备份的log文件(xtrabackup_logfile)到 --target-dir目录~
--stats 统计分析innodb表存储信息,eg. xtrabackup --stats --defaults-file=/data/scrips/mysql_3306.cnf
--prepare 返原innodb前要执行,prepare命令~ eg. xtrabackup --prepare --defaults-file=`pwd`/mysql_3306.cnf --throttle=2000 --target-dir=`pwd`/dbbak
--print-param 主要用于innobackupex脚本copyback操作时, 打印出目标mysqld的参数~
--use-memory= 用于--prepare 或 --stats,在prepare相当于innodb_buffer_pool_size 作用~ eg.xtrabackup --use-memory=1G --stat
--export --prepare操作时,导入其它数据库使用。在使用'ALTER TABLE … IMPORT TABLESPACE' 命令时,输出干净的.ibd files 或 .exp 文件.
--suspend-at-end 在backup操作时用于同步(synchronizing)
--log-stream --backup操作时,输出xtrabackup_logfile内容,innobackupex --stream 就使用此选项~
--incremental-lsn= 用于--backup. Copy only .ibd pages newer than specified LSN 'high:low'
--incremental-basedir= 用于增量备份backup~只拷贝比目标目录中更新的.ibd 文件~
--incremental-dir=name= 用于增量prepare,
--tables= innodb数据库使用file-per-table模式时,可用此选项备份部分表~也可用于stat操作时~
--throttle= 用于限制每秒中磁盘的读写操作~ 在线备份时非常有用~
--create-ib-logfile 用于--prepare时生成ib-logfile~ 注意:当前版本未实现,还是要re–prepare^_^
--tmpdir= 存放temporary files的路径~
3、innobackupex工具
(1)备份操作(下列是几个例子)
####备份employess数据库(普通备份)#### [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --slave-info --databases=employees /root/backup 1> process_log 2>&1 & 注意:将数据库employees备份到目录/root/backup/XXXX下 [root@SQL1 ~]# ls -l /root/backup total 4 drwxr-xr-x 3 root root 4096 Apr 13 14:16 2010-04-13_14-14-43 ####备份给定的数据库列表中的数据库中(普通备份)#### [root@SQL1 ~]# cat backup_db_name school employees [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --slave-info --databases=/root/backup_db_name /root/backup 1> process_log 2>&1 & 或者 [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --slave-info --databases=“school employees” /root/backup 1> process_log 2>&1 & ####备份employess数据库中的employess表(普通备份)#### [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --slave-info --databases="employees.employees" /root/backup 1> process_log 2>&1 & ####备份所有的数据库,并打包(tar方式)##### [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --slave-info --stream=tar /root/backup 1> /root/backup/all_databases.tar 2> process_log & ####备份所有的数据库并压缩,并打包压缩(tar+gzip方式)#### [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --slave-info --stream=tar /root/backup 2> process_log | gzip > /root/backup/all_databases.tar.gz & |
注意:首先要先创建备份目录:/root/backup,--databases=[ db_name.tb_name | db_name ],如果不使用--databases参数的话,那么将备份所有的数据库
(2)恢复操作
(步骤:先apply log,再copy back,最后再chown -R mysql:mysql datadir)
####(普通备份)的还原操作###### [root@SQL1 ~]# ls -l /root/backup/2010-04-13_15-02-37/ total 223484 -rw-r--r-- 1 root root 348 Apr 13 15:02 backup-my.cnf drwxr-xr-x 2 root root 4096 Apr 13 15:03 employees -rw-r--r-- 1 root root 228589568 Apr 13 15:03 ibdata1 -rw-r--r-- 1 root root 0 Apr 13 15:03 mysql-stderr -rw-r--r-- 1 root root 379 Apr 13 15:03 mysql-stdout -rw-r--r-- 1 root root 1 Apr 13 15:03 xtrabackup_binlog_info -rw-r--r-- 1 root root 60 Apr 13 15:03 xtrabackup_checkpoints -rw-r--r-- 1 root root 2048 Apr 13 15:02 xtrabackup_logfile -rw-r--r-- 1 root root 53 Apr 13 15:03 xtrabackup_slave_info [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --apply-log /root/backup/2010-04-13_15-02-37 [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --copy-back /root/backup/2010-04-13_15-02-37 [root@SQL1 ~]# chown -R mysql:mysql /usr/local/mysql/data [root@SQL1 ~]# rm -rf /usr/local/mysql/data/xtrabackup* ####(tar方式备份)的还原操作###### [root@SQL1 ~]# mkdir /root/backup/db [root@SQL1 ~]# tar -ixvf all_databases.tar -C /root/backup/db(先解压,注意必须跟-i参数) [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --apply-log /root/backup/db [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --copy-back /root/backup/db [root@SQL1 ~]# chown -R mysql:mysql /usr/local/mysql/data [root@SQL1 ~]# rm -rf /usr/local/mysql/data/xtrabackup [root@SQL1 ~]# rm -rf /root/backup/db ####(tar+gzip方式备份)的还原操作###### [root@SQL1 ~]# mkdir /root/backup/db [root@SQL1 ~]# tar -izxvf all_databases.tar.gz -C /root/backup/db(先解压,注意必须跟-i参数) [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --apply-log /root/backup/db [root@SQL1 ~]# innobackupex-1.5.1 --defaults-file=/usr/local/mysql/etc/my.cnf --user=root --host=192.168.1.52 --password=XXXX --port=3306 --socket=/tmp/mysql.sock --copy-back /root/backup/db [root@SQL1 ~]# chown -R mysql:mysql /usr/local/mysql/data [root@SQL1 ~]# rm -rf /usr/local/mysql/data/xtrabackup [root@SQL1 ~]# rm -rf /root/backup/db |