书上摘抄 ---深入浅出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'@'localhostidentified 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 备份与恢复的更多相关文章

  1. xtrabackup备份与恢复实践

    说明   xtrabackup  --percona 特点: 开源,在线备份innodb表 支持限速备份,避免对业务造成影响 支持流备 支持增量备份 支持备份文件压缩与加密 支持并行备份与恢复,速度快 ...

  2. MySQL入门篇(七)之Xtrabackup备份与恢复

    一.Xtrabackup介绍 MySQL冷备.mysqldump.MySQL热拷贝都无法实现对数据库进行增量备份.在实际生产环境中增量备份是非常实用的,如果数据大于50G或100G,存储空间足够的情况 ...

  3. Xtrabackup备份与恢复MySQL

    1.innobackupex备份原理 .innobackupex启动并fork一个进程启动xtrabackup,然后等待xtrabackup备份InnoDB文件; .xtrabackup备份时存在两个 ...

  4. Xtrabackup备份与恢复

    一.Xtrabackup介绍 MySQL冷备.mysqldump.MySQL热拷贝都无法实现对数据库进行增量备份.在实际生产环境中增量备份是非常实用的,如果数据大于50G或100G,存储空间足够的情况 ...

  5. 16、Xtrabackup备份与恢复

    XTRABACKUP xtrabackup是percona公司开发的第三方备份软件,只备份innodb引擎表的ibd文件(frm不备份),不备份myisam引擎表.备份性能很高,备份期间没有任和锁,d ...

  6. XtraBackup 备份与恢复实例讲解

    前一篇文章我们讲到了PXB的原理以及安装方法,接下来将详细介绍 XtraBackup 备份和恢复的具体过程. xtrabackup 选项 xtrabackup 工具有许多参数,具体可去官网查询(xtr ...

  7. mysql 开发进阶篇系列 46 物理备份与恢复( xtrabackup的 选项说明,增加备份用户,完全备份案例)

    一. xtrabackup 选项说明 在操作xtrabackup备份与恢复之前,先看下该工具的选项,下面记录了xtrabackup二进制文件的部分命令行选项,后期把常用的选项在补上.点击查看xtrab ...

  8. Mysql—数据备份与恢复

    数据备份 # 备份单个数据库 [root@localhost ~]# mysqldump -h主机名 -u用户名 -p密码 数据库名字 > 备份的数据库名字.sql [root@localhos ...

  9. 【目录】mysql 进阶篇系列

    随笔分类 - mysql 进阶篇系列 mysql 开发进阶篇系列 55 权限与安全(安全事项 ) 摘要: 一. 操作系统层面安全 对于数据库来说,安全很重要,本章将从操作系统和数据库两个层面对mysq ...

随机推荐

  1. 小白都看得懂的Javadoc上手教程

    Javadoc是什么 官方回答: Javadoc is a tool for generating API documentation in HTML format from doc comments ...

  2. Vue:对axios进行简单的二次封装

    主要做3点: 1.配置一个请求地址前缀 2.请求拦截(在请求发出去之前拦截),给所有的请求都带上 token 3.拦截响应,遇到 token 不合法则报错 // 对 axios 的二次封装 impor ...

  3. window下使用cmd查看端口占用的进程,并杀死该进程

    做项目的时候经常会遇到"address already in use"的情况,此时可以选择使用dos命令将该进程杀死. 首先,查找端口对应的进程,使用命令(以进程号8080为例): ...

  4. 纯HTML + CSS制作个人资料卡

    总体预览: 材料:背景图与头像.jpg IDE:VS Code 外部链接:CDN加速的font-awesome图标 <link rel="stylesheet" href=& ...

  5. oracle11g ADG主备切换

    oracle11g ADG主备切换 1.主库 SQL> select name,open_mode,switchover_status from v$database; NAME OPEN_MO ...

  6. SpringBoot集成基于tobato的fastdfs-client实现文件上传下载和删除

    1. 简介   基于tobato的fastdfs-client是一个功能完善的FastDFS客户端工具,它是在FastDFS作者YuQing发布的客户端基础上进行了大量的重构,提供了上传.下载.删除. ...

  7. Nosql 和 Sql 简单概念介绍

    Nosql (非关系数据库) 代表数据库:redis / hbase /mongoDB /CouchDB /Neo4J 存储数据使用的是数据结构化存储方法的集合,意味着数据的存储可以是文档.集合.键值 ...

  8. 浅谈 FHQ-Treap

    关于FHQ-Treap             --作者:BiuBiu_Miku 可能需要的前置知识:    一.树形结构的了解:        树形,顾名思义,就是像树一样有很多分叉口,而这里以二叉 ...

  9. 【超详细】MakeDown(Typora)+PicGo+Gitee实现图床

    [超详细]MakeDown(Typora)+PicGo+Gitee实现图床 序言:我们有时在用makedown整理笔记时想把自己的笔记上传到博客园,可是发现在上传过程中makedown中的图片显示不出 ...

  10. iOS 集成友盟分享图片链接为http时无法加载问题解决

    一.问题描述 UMShareWebpageObject *obj = [UMShareWebpageObject shareObjectWithTitle:title descr:shareText ...