XtraBackup备份mysql5.1.73
一、基础介绍
mysql5.1在源码中配备了两个版本的innodb存储引擎源码:innobase和innodb_plugin,编译安装的时候可以通过参数--with-plugins=innobase,innodb_plugin来指定是否将innodb存储引擎引入,具体这两个参数引入对编译后的mysql产生怎样的差异,后面再做解析。然而对于PerconaXtraBackup,在release版本中有2.0,2.1,2.2三个大版本,然后每个版本都是与mysql发布的innodb存储引擎版本对应,举例来说:
percona-xtrabackup-2.0.8在BUILD.txt中指定了utils/build.sh参数如下:
The script needs the codebase for which the building is targeted, you must
provide it with one of the following values or aliases: ================== ========= =============================================
Value Alias Server
================== ========= =============================================
innodb51_builtin 5.1 build against built-in InnoDB in MySQL 5.1
innodb51 plugin build against InnoDB plugin in MySQL 5.1
innodb55 5.5 build against InnoDB in MySQL 5.5
xtradb51 xtradb build against Percona Server with XtraDB 5.1
xtradb55 xtradb55 build against Percona Server with XtraDB 5.5
innodb56 5.6 build against InnoDB in MySQL 5.6
================== ========= =============================================
而在percona-xtrabackup-2.1.9在BUILD.txt中指定了utils/build.sh参数如下:
The script needs the codebase for which the building is targeted, you must
provide it with one of the following values or aliases: ================== ========= =============================================
Value Alias Server
================== ========= =============================================
innodb51 plugin build against InnoDB plugin in MySQL 5.1
innodb55 5.5 build against InnoDB in MySQL 5.5
xtradb51 xtradb build against Percona Server with XtraDB 5.1
xtradb55 xtradb55 build against Percona Server with XtraDB 5.5
innodb56 5.6 build against InnoDB in MySQL 5.6
================== ========= =============================================
解释一下:从percona-xtrabackup2.1开始取消对innodb built-in版本支持,即:用Percona-Xtrabackup2.1备份5.1built-in版本将会出现如下报错:
innobackupex: Error: Support for MySQL 5.1 with builtin InnoDB (not the plugin) was removed in Percona XtraBackup 2.1. The last version to support MySQL 5.1 with builtin InnoDB was Percona XtraBackup 2.0.
二、Percona-Xtrabackup2.0.8编译安装
cd percona-xtrabackup-2.0.
./utils/build.sh 5.1
编译安装完,备份工具保存在 src/xtrabackup_51,打包xtrabackup_51和innobackupex 到目的服务器的/usr/local/bin目录下,即可执行备份
三、用innobackupex备份多实例mysql数据库
前面讲过,mysql多实例数据库配置文件写在同一个文件中,而这个my.cnf必须位于/etc/my.cnf,否则需要在启动时指定配置文件路径。对于innobackex来说,使用--defaults-file需要读取单个数据库实例的配置文件信息,对于多个实例混合无法识别,故而需要将单实例配置抽出,单独存放,例如将mysql5.1.73多实例安装启动的配置文件抽出如下部分:
[mysqld]
server-id = 3307
port = 3307 socket = /data/mysql_multi/mysql_exa1/mysql.sock
pid-file = /data/mysql_multi/mysql_exa1/mysql.pid
datadir = /data/mysql_multi/mysql_exa1/data
log-error = /data/mysql_multi/mysql_exa1/log/error.log long_query_time = 1
slow_query_log_file = /data/mysql_multi/mysql_exa1/log/slow-query.log log-bin = /data/mysql_multi/mysql_exa1/binlog/mysql-bin
log-bin-index = /data/mysql_multi/mysql_exa1/binlog/mysql-bin.index
expire_logs_days = 2
binlog_format=mixed skip-locking
key_buffer_size = 16M
max_allowed_packet = 1M
table_open_cache = 64
sort_buffer_size = 512K
net_buffer_length = 8K
read_buffer_size = 256K
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 8M innodb_buffer_pool_size = 1G
innodb_additional_mem_pool_size = 2M
#Set .._log_file_size to 25 % of buffer pool size
innodb_log_file_size = 80M
innodb_log_buffer_size = 8M
innodb_flush_log_at_trx_commit = 2
innodb_lock_wait_timeout = 50
innodb_file_per_table = 1
innodb_flush_method = O_DIRECT
innodb_file_io_threads = 4 [mysqldump]
quick
max_allowed_packet = 16M [mysql]
no-auto-rehash
[myisamchk]
key_buffer_size = 20M
sort_buffer_size = 20M
read_buffer = 2M
write_buffer = 2M [mysqlhotcopy]
interactive-timeout
单独保存在 /data/mysql_multi/mysql_exa1/my.cnf,下面开始执行备份
innobackupex --defaults-file=/data/mysql_multi/mysql_exa1/my.cnf --user=root --password= --socket=/data/mysql_multi/mysql_exa1/mysql.sock --databases="dinner" --datadir= /data/mysql_multi/
备份完成后将产生如下目录:/data/mysql_multi/2015-03-03_15-05-56/
下面将备份出来的库恢复到另一个实例中,同样需要做一份第二个实例的单独配置文件 /data/mysql_multi/mysql_exa2/my.cnf,内容和第一份类似,在此不做复述。
执行恢复前的prepare操作:
# innobackupex --defaults-file=/data/mysql_multi/mysql_exa2/my.cnf --user=root --password= --socket=/data/mysql_multi/mysql_exa2/mysql.sock --apply-log --export /data/mysql_multi/--03_15--
然后停掉第二个实例,复制prepare后的ibdata、ib_log和dinner目录到实例2的data目录下,修改权限,重启实例2即可。
四、总结
a. mysql5.1在实现插件式存储引擎时,在标准源码中附带了innobase和innodb_plugin两个版本,而不是像个别书中讲述的删掉innobase目录,将innodb_plugin重命名为innobase,这样操作在对编译configure参数不熟的情况下,很可能导致编译失败。
b. innobackupex是一个调用xtrabackup的perl脚本,当用2.0.8编译完成后,生成的xtrabackup***需要重命名为xtrabackup,并和innobackupex一并放在系统$PATH可找到的bin目录下(个人推荐将这两个工具放在/usr/local/xtrabackup目录下,再用软连接将其连接到/usr/local/bin下面)。
c. Xtrabackup在处理数据库整体迁移时很方便,但是在处理将多个机器上的数据库合并到同一台机器上时,鄙人暂时还没有完全测试成功。
XtraBackup备份mysql5.1.73的更多相关文章
- mysqldump和xtrabackup备份原理实现说明
		
背景: MySQL数据库备份分为逻辑备份和物理备份两大类,犹豫到底用那种备份方式的时候先了解下它们的差异: 逻辑备份的特点是:直接生成SQL语句,在恢复的时候执行备份的SQL语句实现数据库数据的重现. ...
 - Percona Xtrabackup备份mysql(转)
		
add by zhj:另外,参考了Xtrabackup之innobackupex备份恢复详解,我用的是Xtrabackup2.2.6版本, 可以成功备份和恢复指定的数据库. 原文:http://www ...
 - mysql xtrabackup 备份恢复实现,mysql命令备份数据库,打包压缩数据库
		
简介 Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具.特点: (1)备份过程快速.可靠 ...
 - 从xtrabackup备份恢复单表
		
目前对MySQL比较流行的备份方式有两种,一种上是使用自带的mysqldump,另一种是xtrabackup,对于数据时大的环境,普遍使用了xtrabackup+binlog进行全量或者增量备份,那么 ...
 - 用xtrabackup2.4备份mysql5.6.30一直显示log scanned up to
		
用xtrabackup2.4备份mysql5.6.30一直显示log scanned up to 一直处于log scanned up to,只能ctrl+c强制终止备份 没有大事务 停止xtraba ...
 - 从xtrabackup备份恢复单表【转】
		
目前对MySQL比较流行的备份方式有两种,一种上是使用自带的mysqldump,另一种是xtrabackup,对于数据时大的环境,普遍使用了xtrabackup+binlog进行全量或者增量备份,那么 ...
 - Database基础(五):使用binlog日志、XtraBackup备份工具、MySQL AB复制
		
一.使用binlog日志 目标: 利用binlog恢复库表,要求如下: 启用binlog日志 创建db1库tb1表,插入3条记录 删除tb1表中刚插入的3条记录 使用mysqlbinlog恢复删除的3 ...
 - xtrabackup备份还原mariadb数据库
		
一.xtrabackup 简介 xtrabackup 是由percona公司开源免费的数据库热备软件,它能对InnoDB数据库和XtraDB存储引擎的数据库非阻塞地备份,对于myisam的备份同样需要 ...
 - MySQL自动备份实战--xtrabackup备份
		
MySQL数据备份企业实战.制作shell脚本 功能1:使用xtrabackup以每周为一个备份周期做备份(数据库+二进制日志,备份至本地/data/backup).提示: 周一某个时间点做一次完全备 ...
 
随机推荐
- VUE -- ejs模板的书写
			
1.EJS是一个简单高效的模板语言,通过数据和模板,可以生成HTML标记文本.可以说EJS是一个JavaScript库,EJS可以同时运行在客户端和服务器端,客户端安装直接引入文件即可,服务器端用np ...
 - vue axios跨域请求,apache服务器设置
			
问题所在axios请求会发送两次请求 也就是说,它会先使用options去测试,你这个接口是否能够正常通讯,如果不能就不会发送真正的请求过来,如果测试通讯正常,则开始正常请求. 思路: 跨域--> ...
 - Shell--变量键盘读取、数组与声明:read,array,declare
			
1.read read [-pt] variable -P:后面可以接提示信息 -t:后面可以接等待的秒数,时间到后等待结束 read后面不加任何参数,直接加变量名称,那么就会主动出现一个空白行等待你 ...
 - 拉格朗日对偶与kkt条件
 - 新人补钙系列教程之:AS3事件处理--事件流
			
一个flash应用程序可能会非常复杂,比如,有很多可视实例嵌套在一起,这样的话会形成一个树形结构,这个结构的根是stage,然后一级级到不同的实例,一般来说,要把这个树形结构倒过来看,即stage在顶 ...
 - 利用excel去除txt文本中重复项
			
2017-04-10 1.要去重的文件,点击右键,选择程序. 2.选择excel表格或者wps表格. 3.excel表格去重:选中单元格——数据——筛选——高级筛选——选择不重复记录——确定 wps表 ...
 - HTML5 Canvas 龟羊赛跑
			
从一张图上截取不同图块,动态显示在canvas上,形成赛跑的效果.完整代码图片下载请点击 https://files.cnblogs.com/files/xiandedanteng/turtleShe ...
 - VB,Visual Basic如何修改代码文本大小和字体
			
工具-选项-编辑器格式 修改之后效果如图所示
 - C++11之function模板和bind函数适配器
			
在C++98中,可以使用函数指针,调用函数,可以参考之前的一篇文章:类的成员函数指针和mem_fun适配器的用法. 简单的函数调用 对于函数: void foo(const string &a ...
 - linux 设置时间
			
1.图形界面里面点击右上角的 “时间” 2.设置,edit 找到china G8区 date发现还没有生效 3.reboot 重启才生效了