ibbackup参考手册

一.关于ibbackup

1.注册相关

ibbackup是一个收费的备份软件,在购买的时候,需要注册,比如填写使用该软件的主机名,然后,会自动把购买者填写的主机名写入到ibbackup这个二进制文件里面。然后就可以下载使用了。所以说,ibbackup是把注册的主机名“刻录”到其中的。

 

2.软件结构

该软件由  ibbackup  innobackup  主要这两部分组成

其中ibbackup  是主要的备份软件。(可执行文件)

Innobackup 是一个perl脚本。它会调用ibbackup来执行备份

 

3.支持的备份

在线备份、增量备份、全量备份...


二.备份基本原理

创建备份文件夹,然后通过读取my.cnf获取数据文件和事物日志文件的大小、个数、路径等信息。


1.复制innodb日志文件

1)记录一个checkpoint之前的LSN,并从该LSN开始,复制到最近的checkpointLSN结束的所有事物日志。并记录这两个LSN。比如

start lsn 3 35257344, end lsn3 35257702

其中 checkpoint 对应 LSN 为 3 35257702

 

 

2)从复制开始到结束,对于备份好的innodb日志文件的回滚信息,只有部分日志文件有必要被复制和覆盖。


2.复制数据文件及索引

1)依次复制ibdata文件、ibd文件

ibbackup 通过对 InnoDB 数据文件进行压缩、复制完成备份。

 

2)备份文件能被压缩70%--90%。之所以能压缩这么多,是因为,在做备份时,复制数据文件的过程中,会忽略存储于每个block中没有使用的存储空间以及忽略没有使用的空页(empty page)。(注意压缩级别也是可以设置的,ibbackup分为0—9个压缩级别,默认为1)

 

3)当数据文件被复制和压缩的时,最新的LSN和最旧的LSN会被记录。

 

3.备份MyISAM表

备份MyISAM会使用innobackup。(这个操作会连接mysqlserver)

1)sql flush tables  with read lock ;刷表并设只读锁表

2)myisam表 &&indexes,表定义.frm等文件被mysqlbackup备份

 

4.备份innodb日志文件

因为在备份数据文件的时间,会有新的数据被更改,产生新的LSN,所以需要备份这段时间的innodb日志文件。比如

start lsn 3 35257702, end lsn3 35257722

其中,lsn 3 35257702 就是二.1.1)中提到的checkpoint

 

三.恢复基本原理

1.解压数据文件到数据目录

2.应用innodb logfile 到数据文件中,确保数据一致性

3.重建innodb logfile  (在2的基础上产生)

4.恢复myisam及其它文件

 

在恢复的过程中,不是从lsn 3 35257702开始恢复(虽然35257702是checkpoint),而是从35257344开始一直恢复到35257722.

 

四.使用方法

1. 执行备份

perlinnobackup --user=user_name --password=user_password  --ibbackup=/home/longxibendi/backup/ibbackup   /etc/my.cnf    /home/longxibendi/back_up/

 

上面的参数可以用innobackup –help  查看

其中  user是数据库用户名,password是数据库密码,ibbackup是可执行的备份文件,my.cnf是MySQL配置文件,/home/longxibendi/back_up  是备份后的文件所在目录。实际上,会在back_up下再建立以当前时间为参数的var文件夹,其中存放的备份文件。比如

Back_up/var. 20110812140418

 

执行这个备份之后产生的文件有(为了对比方便,这里列出了对应文件md5值)

69230a608907c16f4022dec4db8a8325  ./backup-my.cnf
4aebba1ba15cbf2eeffd3c88bb3176f7  ./ibbackup_binlog_info
e2eab75f272632e91862c804b75504ec  ./ibbackup_logfile
703122eefe9cf5b8df33e4ae54c0993f  ./ibdata1
md5sum: ./longxibendi: Is adirectory
md5sum: ./mysql: Is adirectory
d41d8cd98f00b204e9800998ecf8427e  ./mysql-stderr
c311dd124e0701040e1faef783f67f6f  ./mysql-stdout
md5sum: ./test: Is adirectory

 

 

2.应用事务日志

上面四.1进行了全备份,但是在备份过程中可能产生了写操作,这就需要应用刚备份的事物日志执行前滚操作,把数据从innodb ib_logfile写入到data文件中。在此过程中会产生新的ib_logfile,删除备份之后的ib_logfile。

perl innobackup --applay-log--user=user_name --password=user_password --ibbackup=/home/longxibendi/backup/ibbackup   /etc/my.cnf    /home/longxibendi/back_up/var.20110812140418

 

应用重做日志之后,产生的文件如下(前面是对应的MD5值)

69230a608907c16f4022dec4db8a8325  ./backup-my.cnf
4aebba1ba15cbf2eeffd3c88bb3176f7  ./ibbackup_binlog_info
e2eab75f272632e91862c804b75504ec  ./ibbackup_logfile
4f34f7f4c6913fb88b0671765ac6c455  ./ibdata1
06b01370cc9e7c8547211348a0d8ac07  ./ib_logfile0
3566de3a97906edb98d004d6b947ae9b  ./ib_logfile1
3566de3a97906edb98d004d6b947ae9b  ./ib_logfile2
md5sum: ./longxibendi: Is adirectory
md5sum: ./mysql: Is adirectory
d41d8cd98f00b204e9800998ecf8427e  ./mysql-stderr
c311dd124e0701040e1faef783f67f6f  ./mysql-stdout
md5sum: ./test: Is adirectory

 

从上面结果得知,使用—applay-log  之后,会应用ibbackup_logfile文件执行前滚ibdata文件,并产生ib_logfile 。

 

 

五.企业级使用

在使用过程中,需要先修改主机名,执行备份,再修改主机名恢复原主机名。

 


 


声明:本文档可以随意更改,但必须署名原作者

作者:凤凰舞者