xtrabackup 备份与恢复
书上摘抄 ---深入浅出mysql 448页
grant reload on *.* to 'backup'@'localhost' identified by '123456';
grant reload,lock tables on *.* to 'backup'@'localhost' identified by '123456';
grant reload,lock tables,replication client on *.* to 'backup'@'localhost' identified by '123456';
grant reload,lock tables,replication client,create tablespace on *.* to 'backup'@'localhost' identified by '123456';
grant reload,lock tables,replication client,create tablespace,super on *.* to 'backup'@'localhost' identified by '123456';
1.grant reload,lock tables,replication client,create tablespace,super on *.* to 'backup'@'%';
2.增量备份
在mysql中进行增量备份需要时,首先需要进行一次全量备份,之后的增量备份在上一次的增量备份
创建基础备份 base
innobackupex --user=backup --password='123456' --socket=/tmp/mysql.sock --defaults-file=/tmp/my.cnf /data/backup/hotbackup/base --no-timestamp
创建增量备份
innobackupex --user=backup --password='123456' --socket=/tmp/mysql.sock --defaults-file=/tmp/my.cnf --incremental /data/backup/hotbackup/incremental_one --incremental-basedir=/data/backup/hotbackup/base --no-timestamp --parallel=2
再次创建增量备份
innobackupex --user=backup --password='123456' --socket=/tmp/mysql.sock --defaults-file=/tmp/my.cnf --incremental /data/backup/hotbackup/incremental_two --incremental-basedir=/data/backup/hotbackup/increament_one --no-timestamp --parallel=2
3.增量备份的恢复
恢复基础备份(全备)
恢复增量备份到基础备份(开始恢复的增量备份要加--redo-only 参数,到最后一次增量备份去掉--redo-only参数)
--redo-only的意思是之应用xtrabackup日志中已经提交的事务数据,不回滚还未提交的数据
innobackupex --apply-log --redo-only --use-memory=2g /data/backup/hotbackup/base
将增量备份increament_one应用到基础备份base:
innobackupex --apply-log --redo-only --use-memory=2g /data/backup/hotbackup/base --incremental-basedir=/data/backup/hotbackup/increament_one
将增量备份increament_two应用到基础备份base:
innobackupex --apply-log --use-memory=2g /data/backup/hotbackup/base --incremental-basedir=/data/backup/hotbackup/increament_two
将所有合在一起的基础备份整体进行一次apply操作,回滚未提交的数据
innobackupex --apply-log --use-memory=2g /data/backup/hotbackup/base
将恢复完的备份复制到数据文件目录中,赋权,然后启动mysql数据库
mysqldmin -s /tm/mysql.sock shutdown
mv /home/mysql_test/mysqlhone/data /home/mysql_test/mysqlhome/_data_back
mkdir /home/mysql_test/mysqlhome/data
innodbackupex --defaults-file=/tmp/my.cnf --copy-back --rsync /data/backup/hotbackup/full
chown -R mysql.mysql /home/mysql_test/mysqlhome/data
启动数据库
*********************************************************************************************************************
操作实录:
问题:貌似只要是增量备份,一定要加--no-timestamp,否则会报错的
grant reload,lock tables,replication client,create tablespace,super on *.* to 'backup'@'localhost' identified by '123456';
***********************************************************
全量备份 + --no-timestamp
1.[root@test]#innobackupex --user=root /root/backup --no-timestamp (加上--no-timestamp参数的时候,backup目录不能存在,否则会报innobackupex: Error: Failed to create backup directory /root/backup: File exists at /usr/bin/innobackupex line 3808.)
增量备份1
innobackupex --user=root --incremental /root/backup/incremental_one --incremental-basedir=/root/backup --no-timestamp
增量备份2
innobackupex --user=root --incremental /root/backup/incremental_two --incremental-basedir=/root/backup/incremental_one --no-timestamp
************************************************************************************************************************
全量备份 不加--no-timestamp
2.[root@test]#innobackupex --user=root /root/backup  (不加--no-timestamp的时候,backup目录一定要存在,要不然会报innobackupex: Error: Failed to create backup directory /root/backup/2014-05-22_02-07-14: No such file or directory at /usr/bin/innobackupex line 3808.)
[root@test]# ls -al /root/backup/
total 12
drwxr-xr-x. 3 root root 4096 May 22 02:07 .
dr-xr-x---. 6 root root 4096 May 22 02:07 ..
drwxr-xr-x. 6 root root 4096 May 22 02:07 2014-05-22_17-52-53
增量备份
增量备份1
innobackupex --user=root --incremental /root/backup/incremental_one --incremental-basedir=/root/backup/2014-05-22_17-52-53 --no-timestamp (这个参数一定要加,要不然无法备份成功)--parallel=2
增量备份2
innobackupex --user=root /root/backup/incremental_two --incremental-basedir=/root/backup/increament_one --no-timestamp --parallel=2
增量备份的恢复:
恢复基础备份(全备)
恢复增量备份到基础备份(开始恢复的增量备份要加--redo-only 参数,到最后一次增量备份去掉--redo-only参数
--redo-only的意思是之应用xtrabackup日志中已经提交的事务数据,不回滚还未提交的数据
innobackupex --apply-log --redo-only /root/backup/2014-05-22_17-52-53
将增量备份increament_one应用到基础备份base:
innobackupex --apply-log --redo-only /root/backup/2014-05-22_17-52-53 --incremental-basedir=/root/backup/increament_one
将增量备份increament_two应用到基础备份base:
innobackupex --apply-log /root/backup/2014-05-22_17-52-53 --incremental-basedir=/root/backup/increament_two
将所有合在一起的基础备份整体进行一次apply操作,回滚未提交的数据
innobackupex --apply-log /root/backup/2014-05-22_17-52-53
将恢复完的备份复制到数据文件目录中,赋权,然后启动mysql数据库
/usr/local/mysql/bin/mysqladmin shutdown 关闭数据库
mv /var/lib/mysql/ /var/lib/mysql_bak 把原数据库目录重命名
mkdir /var/lib/mysql 新建原数据库目录
innodbackupex --copy-back --rsync /root/backup/2014-05-22_17-52-53
chown -R mysql.mysql /var/lib/mysql
启动数据库
xtrabackup 备份与恢复的更多相关文章
- xtrabackup备份与恢复实践
		
说明 xtrabackup --percona 特点: 开源,在线备份innodb表 支持限速备份,避免对业务造成影响 支持流备 支持增量备份 支持备份文件压缩与加密 支持并行备份与恢复,速度快 ...
 - MySQL入门篇(七)之Xtrabackup备份与恢复
		
一.Xtrabackup介绍 MySQL冷备.mysqldump.MySQL热拷贝都无法实现对数据库进行增量备份.在实际生产环境中增量备份是非常实用的,如果数据大于50G或100G,存储空间足够的情况 ...
 - Xtrabackup备份与恢复MySQL
		
1.innobackupex备份原理 .innobackupex启动并fork一个进程启动xtrabackup,然后等待xtrabackup备份InnoDB文件; .xtrabackup备份时存在两个 ...
 - Xtrabackup备份与恢复
		
一.Xtrabackup介绍 MySQL冷备.mysqldump.MySQL热拷贝都无法实现对数据库进行增量备份.在实际生产环境中增量备份是非常实用的,如果数据大于50G或100G,存储空间足够的情况 ...
 - 16、Xtrabackup备份与恢复
		
XTRABACKUP xtrabackup是percona公司开发的第三方备份软件,只备份innodb引擎表的ibd文件(frm不备份),不备份myisam引擎表.备份性能很高,备份期间没有任和锁,d ...
 - XtraBackup 备份与恢复实例讲解
		
前一篇文章我们讲到了PXB的原理以及安装方法,接下来将详细介绍 XtraBackup 备份和恢复的具体过程. xtrabackup 选项 xtrabackup 工具有许多参数,具体可去官网查询(xtr ...
 - mysql 开发进阶篇系列 46 物理备份与恢复( xtrabackup的 选项说明,增加备份用户,完全备份案例)
		
一. xtrabackup 选项说明 在操作xtrabackup备份与恢复之前,先看下该工具的选项,下面记录了xtrabackup二进制文件的部分命令行选项,后期把常用的选项在补上.点击查看xtrab ...
 - Mysql—数据备份与恢复
		
数据备份 # 备份单个数据库 [root@localhost ~]# mysqldump -h主机名 -u用户名 -p密码 数据库名字 > 备份的数据库名字.sql [root@localhos ...
 - 【目录】mysql 进阶篇系列
		
随笔分类 - mysql 进阶篇系列 mysql 开发进阶篇系列 55 权限与安全(安全事项 ) 摘要: 一. 操作系统层面安全 对于数据库来说,安全很重要,本章将从操作系统和数据库两个层面对mysq ...
 
随机推荐
- 通过Spring profile方式实现多环境部署
			
1 多环境部署 在实际软件开发和部署过程中,我们的软件往往需要在不同的运行环境中运行.例如,各个环境数据库地址不同,需要单独配置.spring高级装备中提供profile,来支持多环境部署. 1.1 ...
 - window+nginx+php
			
今天在Windows上配置了下nginx,看了不少其他大牛们记录的博客,自己也操作了一番,记录一下备忘. nginx download: http://nginx.org/en/download.ht ...
 - 微信小程序api拦截器
			
微信小程序api拦截器 完美兼容原生小程序项目 完美兼用小程序api的原本调用方式,无痛迁移 小程序api全Promise化 和axios一样的请求方式 小程序api自定义拦截调用参数和返回结果 强大 ...
 - MySQL锁(三)行锁:幻读是什么?如何解决幻读?
			
概述 前面两篇文章介绍了MySQL的全局锁和表级锁,今天就介绍一下MySQL的行锁. MySQL的行锁是各个引擎内部实现的,不是所有的引擎支持行锁,例如MyISAM就不支持行锁. 不支持行锁就意味着在 ...
 - js上 十四、对象
			
十四.对象 #1.初识对象 什么是对象? 在js中,一切皆是对象. 对象,生活中可见和不可见的东西,在世界中,客观存在的都是一个对象. 桌子,笔记本,手机,人. 在日常生活中,我们是如何来描述这个对象 ...
 - vue第十二单元(vue中过渡效果的实现)
			
第十二单元(vue中过渡效果的实现) #课程目标 熟练掌握transition组件的用法 熟练使用transition组件做过渡特效 熟练使用transition组件做动画特效 了解使用transit ...
 - 【Idea插件】kotlin的orm框架一键生成代码框架
			
@font-face { font-family: octicons-link; src: url("data:font/woff;charset=utf-8;base64,d09GRgAB ...
 - 记一次真实的webpack优化经历
			
前言 公司目前现有的一款产品是使用vue v2.0框架实现的,配套的打包工具为webpack v3.0.整个项目大概有80多个vue文件,也算不上什么大型项目. 只不过每次头疼的就是打包所耗费的时间平 ...
 - Python 微信公众号文章爬取
			
一.思路 我们通过网页版的微信公众平台的图文消息中的超链接获取到我们需要的接口 从接口中我们可以得到对应的微信公众号和对应的所有微信公众号文章. 二.接口分析 获取微信公众号的接口: https:// ...
 - python 做回归
			
1 一元线性回归 线性回归是一种简单的模型,但受到广泛应用,比如预测商品价格,成本评估等,都可以用一元线性模型.y = f(x) 叫做一元函数,回归意思就是根据已知数据复原某些值,线性回归(regre ...