xtrabackup 备份工具的使用

实用的innodb备份工具,大家可以试试看。
近来好多人都在使用此备份工具。

1,下载
http://www.percona.com/downloads/XtraBackup/LATEST/RPM/rhel6/x86_64/
可以根据具体系统版本来选择

2,User’s Manual
http://www.percona.com/doc/percona-xtrabackup/2.1/manual.html

3,yum安装各种包
yum install libaio libaio-devel perl-Time-HiRes curl curl-devel zlib-devel openssl-devel perl cpio expat-devel gettext-devel perl-ExtUtils-MakeMaker perl-DBD-MySQL.* package bzr bison ncurses-devel zlib-devel gcc gcc-c++ -y

yum install perl-DB* perl-Time*

4,使用rpm包安装xtrabackup
rpm -ivh ./percona-xtrabackup-2.1.8-733.rhel6.x86_64.rpm

5,检查服务器是否安装了mysql,若没有则需要提前安装。
且my.cnf 中必须有配置datadir=/var/lib/mysql 。若没有配置则可以拷贝一份线上的my.cnf,然后加上此项。

下面开始重头戏讲一下备份的具体情况:

全量备份:innobackupex --user=root --password='' --defaults-file=/data/mysql/server/3307/mysql-5536/my.cnf --port=3307 --socket=/data/mysql/server/3307/mysql-5536/mysql.sock --parallel=8 /data/alldata/

ls -l /data/alldata/2014-03-25_10-48-36 自动创建此时间名称目录
该语句将拷贝数据文件(由my.cnf里的变量datadir指定)至备份目录下(/data/alldata/),注意:如果不指定--defaults-file,默认值为/etc/my.cnf。我的默认配置文件中没有指定datadir,当是以为需要重启数据库,其实不必,只要将配置文件拷贝到某个位置,修改一下,备份时调用即可,我的拷贝到/data下,备份成功后,将在备份目录下创建一个时间戳目录(本例创建的目录为/data/alldata/2014-03-25_10-48-36),在该目录下存放备份文件

增量备份:
增量备份需要基于全备,先假设我们已经有了一个全备(ll /data/alldata/2014-03-25_10-48-36/),我们需要在该全备的基础上做增量备份

innobackupex --defaults-file=/data/mysql/server/3307/mysql-5536/my.cnf --user=root --password='' --port=3307 --socket=/data/mysql/server/3307/mysql-5536/mysql.sock --incremental-basedir=/data/alldata/2014-03-25_10-48-36/ --incremental /data/partdata

innobackupex --defaults-file=/data/mysql/server/3307/mysql-5536/my.cnf --user=root --password='' --port=3307 --socket=/data/mysql/server/3307/mysql-5536/mysql.sock --incremental-basedir=/data/partdata/2014-03-25_10-52-40/ --incremental /data/partdata
[root@NYSJHL65-195 mysql-5536]# ll -tr /data/partdata/
total 8
drwxr-xr-x 6 root root 4096 Mar 25 10:54 2014-03-25_10-52-40 # 第1次基于全量的增量备份
drwxr-xr-x 6 root root 4096 Mar 25 10:57 2014-03-25_10-56-34 # 第2次基于第一增量的增量备份

恢复操作

全量备份的恢复:

恢复之前,要先关闭数据库,并且删除数据文件和日志文件 即默认/var/lib/mysql里面所有内容都清除
innobackupex --user=root --password='' --defaults-file=/data/mysql/server/3307/mysql-5536/my.cnf --port=3307 --socket=/data/mysql/server/3307/mysql-5536/mysql.sock --parallel=8 --use-memory=1G --apply-log /data/alldata/2014-03-25_10-48-36/
innobackupex --user=root --password='' --defaults-file=/data/mysql/server/3307/mysql-5536/my.cnf --port=3307 --socket=/data/mysql/server/3307/mysql-5536/mysql.sock --parallel=8 --copy-back /data/alldata/2014-03-25_10-48-36/
恢复分为两个步骤,第1步是apply-log,为了加快速度,一般建议设置--use-memory,这个步骤完成之后,目录/data/alldata/2014-01-29_09-05-25下的备份文件已经准备就绪第2步是copy-back,即把备份文件拷贝至原数据目录下。
恢复完成之后,要记得检查数据目录的所有者和权限是否正确
chown mysql:mysql /var/lib/mysql 存放数据和表的地方
此时已经恢复到了全量备份的数据

包含增量备份的恢复:

增量备份的恢复:
第一步;
innobackupex --apply-log --redo-only /data/alldata/2014-03-25_10-48-36 --user=root --password='' --defaults-file=/data/mysql/server/3307/mysql-5536/my.cnf --port=3307 --socket=/data/mysql/server/3307/mysql-5536/mysql.sock
innobackupex --apply-log --redo-only /data/alldata/2014-03-25_10-48-36 --incremental-dir=/data/partdata/2014-03-25_10-52-40 --user=root --password='' --defaults-file=/data/mysql/server/3307/mysql-5536/my.cnf --port=3307 --socket=/data/mysql/server/3307/mysql-5536/mysql.sock
innobackupex --apply-log /data/alldata/2014-03-25_10-48-36/ --incremental-dir=/data/partdata/2014-03-25_10-56-34 --user=root --password='' --defaults-file=/data/mysql/server/3307/mysql-5536/my.cnf --port=3307 --socket=/data/mysql/server/3307/mysql-5536/mysql.sock

-----语法------
innobackupex --apply-log --redo-only BASE-DIR
innobackupex --apply-log --redo-only BASE-DIR --incremental-dir=INCREMENTAL-DIR-1
innobackupex --apply-log BASE-DIR --incremental-dir=INCREMENTAL-DIR-2


其中BASE-DIR是指全备目录,INCREMENTAL-DIR-1是指第一次的增量备份,INCREMENTAL-DIR-2是指第二次的增量备份,以此类推。

这里要注意的是:最后一步的增量备份并没有--redo-only选项!还有,可以使用--use_memory提高性能。

以上语句执行成功之后,最终数据在BASE-DIR(即全备目录)下。

第二步:拷贝
innobackupex --copy-back /data/alldata/2014-03-25_10-48-36/ --user=root --password='' --defaults-file=/data/mysql/server/3307/mysql-5536/my.cnf
innobackupex --copy-back BASE-DIR ###语法

同样地,拷贝结束之后,记得检查下数据目录的权限是否正确。

chown -R mysql:mysql ${mysqldir}/data ${mysqldir}/logs

最后查看一下my.cnf 没有问题就可以启动mysql了

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容