A.1全库备份.

命令:

mysqlbackup--defaults-file=/home/mysql-server/mysql3/my.cnf  --user=root --password=root  --databases="mysql total2" --with-timestamp   --backup-dir=/home/mysql-server/backup   backup

参数说明:

--defaults-filemy.cnf文件的路径,主要用于一台服务器多个mysql服务.默认位置是/etc/my.cnf

--user用户名,这个用户必须在mysql库里面有创建table和查询,插入的权限.在备份的过程中.mysqlbackup会在mysql库下建立backup_history, backup_progress表.用户保留备份的历史信息和备份的基础信息.

--password密码

--database需要备份的数据库,要备份多个数据库需要用””包括起来,每个数据库中间用空格分开

--with-timestamp用户创建一个备份目录下面当前时间的文件夹,如果没有这个参数,多次备份时,制定同一个目录,会使上一次备份的文件覆盖掉.

--backup-dir备份的目录

Backup表明,这是备份操作

A.2全库还原.

第一步:检测事务日志

Mysqlbackup --defaults-file=/home/mysql-server/mysql2/my.cnf--backup-dir=/home/mysql-server/backup/2012-03-21_14-01-34/  apply-log

参数说明:

apply-log:因为在备份的时候是在线的,如果有新插入的SQL语句,会记录新增加的LSN点,然后新修改的页面会放到这个文件里面(ibbackup_logfile),同时也会放到表空间里面.当还原使用这个参数的时候,mysqlbackup会检测ibbackup_logfile和表空间的LSN点,然后比较ibbackup_logfile文件表空间LSN的差值,把这个值放到事务日志LOG里面.(事务日志如果填满了,会进入表空间的)

第二步:copy物理文件

mysqlbackup --defaults-file=/home/mysql-server/mysql2/my.cnf--backup-dir=/home/mysql-server/backup/2012-03-21_14-01-34/  --innodb_log_files_in_group=2  copy-back

# 注意:在还原的时候,my.cnf文件中必要要有datadir的参数

B.1压缩全库备份

mysqlbackup--defaults-file=/home/mysql-server/mysql3/my.cnf  --user=root --password=root --compress-level=1 --databases="mysql total2" --with-timestamp   --backup-dir=/home/mysql-server/backup  backup

参数说明:

--compress-level=1

1为快速压缩.共有9个等级

B.2压缩还原

第一步:检测事务日志,并解压

mysqlbackup --defaults-file=/home/mysql-server/mysql2/my.cnf --uncompress --backup-dir=/home/mysql-server/backup/2012-03-21_14-08-33/ apply-log

uncompress解压压缩后的文件.

第二步:copy物理文件

mysqlbackup --defaults-file=/home/mysql-server/mysql2/my.cnf --innodb_log_files_in_group=2 --backup-dir=/home/mysql-server/backup/2012-03-21_14-08-33/copy-back

# 注意:在还原的时候,my.cnf文件中必要要有datadir的参数

增量备份不支持压缩. backup-and-apply-log参数不能跟--compress-level同用

C.1备份时,同时释放事务日志

备份

mysqlbackup  --defaults-file=/home/mysql-server/mysql3/my.cnf  --user=root --password=root  --databases="mysql total2" --with-timestamp     --backup-dir=/home/mysql-server/backup  backup-and-apply-log

参数说明:

backup-and-apply-log这个参数,在备份的时候,就把事务日志检测的功能就完成了,并把ibbackup_logfile与表空间差值的LSN内容放入到了事务日志里面,所以在还原的时候,就只需要备份物理文件就行

还原

mysqlbackup --defaults-file=/home/mysql-server/mysql2/my.cnf --innodb_log_files_in_group=2 --backup-dir=/home/mysql-server/backup/2012-03-21_19-25-09/  copy-back

D.1增量备份

第一次增量备份:

mysqlbackup  --defaults-file=/home/mysql-server/mysql3/my.cnf  --user=root --password=root   --with-timestamp

--databases=”mysql total2” --incremental --incremental-backup-dir=/home/mysql-server/in/  --incremental-base=dir:/home/mysql-server/backup/2012-03-22_11-10-28  backup

参数说明:

--incremental:代表为增量备份.

--incremental-backup-dir :增量备份存放到哪个路径下

--incremental-base :增量备份的基础备份或增量备份的文件

第二次增量备份:

mysqlbackup  --defaults-file=/home/mysql-server/mysql3/my.cnf  --user=root --password=root   --with-timestamp

--databases=”mysql total2”  --incremental --incremental-backup-dir=/home/mysql-server/in/  --incremental-base=dir:/home/mysql-server/backup/2012-03-22_11-15-28  backup

参数说明:

--incremental-base :这里的备份,就是上一次增量备份的路径

增量备份原理:增量备份是基于第一次的完整备份之后,通过完整最后的LSN点这个基础在往后进行备份.当第二次增量备份的时,就基于前一次增量备份的LSN点的基础在进行备份.所以--incremental-base这个参数在增量备份的时候,是指向上一次全备份或增量备份的LSN点

D.2增量还原

1.全备检测匹配释放事务日志

mysqlbackup --defaults-file=/home/mysql-server/mysql2/my.cnf  --backup-dir=/home/mysql-server/backup/2012-03-21_17-59-54/ apply-log

2.检测匹配释放第一次的增量备份

mysqlbackup  --backup-dir=/home/mysql-server/backup/2012-03-21_17-59-54/  --incremental-backup-dir=/home/mysql-server/in/2012-03-22_11-47-47/  apply-incremental-backup

3.检测匹配释放第二次的增量备份

mysqlbackup  --backup-dir=/home/mysql-server/backup/2012-03-21_17-59-54/  --incremental-backup-dir=/home/mysql-server/in/2012-03-22_11-50-47/  apply-incremental-backup

4.最后进行物理文件复制

mysqlbackup --defaults-file=/home/mysql-server/mysql2/my.cnf  --backup-dir=/home/mysql-server/backup/2012-03-21_17-59-54/copy-back

增量还原原理:

1.首先检测匹配释放全备事务日志文件(当然如果备份中使用了backup-and-apply-log,在备份的时候,已经检测匹配了,就不需要这一步了)

2.第一次增量备份的文件释放到全备文件里面.(首先会进入事务日志,然后是表空间),所以--backup-dir指向全备目录(基于LSN点向后增加)

3.第二次增量备份的文件也是释放到全备文件里面. (首先会进入事务日志,然后是表空间),因为第一次的增量备份后,全库里面已经有了第一次的LSN点,所以二次还原的时候同样指向全备文件里面使LSN点在外后增加

4.因为增量的页面,已经全部进入了事务日志或表空间,这个时候,就可以直接备份物理文件了.

但最后依然记住…

# =======================================================================

把先备份的系统库MV到原来的地方

修改data目录的权限(如果你设置的是已MySQL用户访问的话)

chown -R mysql.mysql data

# =========================================================================

在启动mysql server..

Mysqlbackup工作原理

1.mysqlbackup对innodb的表空间进行物理复制,但是,它是记录LSN点的,在备份过程中,新增加的输入直接写入备份文件的ibbackup_logfile中.同时记录最后的LSN点

2.mysqlbackup对myisam进行的是锁表全备.就算是增量备份,它依然是全备.

3.还原的时候,检测对比ibbackup_logfile文件里面与表空间里面的差值,使ibbackup_logfile里面的数据进入事务日志或表空间

4.在备份文件中的meta/backup_variables.txt文件中记录了备份的一些信息

[backup_variables]

start_lsn=1602048#开始备份的LSN点

end_lsn=687810168# 结束LSN点

apply_log_done=1#是否释放检测ibbackup_logfile文件(0表示没有,1表示已经释放)

is_incremental=0#是否是增量为增量备份文件(0:否,1:是)

is_incremental_with_redo_log_only=0#只配置重做日志,当输入数据大小重做日志大小时,会有一场抛出

is_partial=1#是服务器备份还是部分备份(0表示全服务器备份,1表示部分备份)

is_compressed=0#是否压缩(0表示没有压缩,1表示压缩)

binlog_position=mysql-bin.000001:107#二进制文件大小

is_onlyinnodb=0#是否只备份了innodb的表

文章转自:http://blog.csdn.net/m582445672/article/details/7649944

MySQL官方备份_Mysqlbackup 备份详解(mysql官方备份工具)相关推荐

  1. mysql mgr 三节点_详解MySQL 5.7 MGR单主确定主节点方法

    我们行MGR年底要上线了,每天都要看官方文档学习,做测试,坚持每天写一个小知识点,有想一起学习的么~ MySQL 5.7 MGR单主确定主节点是哪个,我们可以通过成员ID来判断,然后结合read_on ...

  2. mysql 编辑数据库内容_详解mysql数据库增删改操作

    插入数据 insert into 表名(列名1,列名2,列名3) values(值1,值2,值3); insert into user(user_id,name,age) values(1,'nice ...

  3. mysql临键锁_详解 MySql InnoDB 中的三种行锁(记录锁、间隙锁与临键锁)

    详解 MySql InnoDB 中的三种行锁(记录锁.间隙锁与临键锁) 前言 InnoDB 通过 MVCC 和 NEXT-KEY Locks,解决了在可重复读的事务隔离级别下出现幻读的问题.MVCC  ...

  4. mysql 的dcl语句_详解MySQL第三篇—DCL语句

    DCL(Data Control Language)语句:数据控制语句,用于控制不同数据段直接的许可和访问级别的语句.这些语句定义了数据库.表.字段.用户的访问权限和安全级别.主要的语句关键字包括 g ...

  5. mysql通配符escape使用_详解MySQL like如何查询包含'%'的字段(ESCAPE用法)

    在SQl like语句中,比如 SELECT * FROM user WHERE username LIKE '%luchi%' SELECT * FROM user WHERE username L ...

  6. mysql通配符escape使用_详解MySQL like如何查询包含#39;%#39;的字段(ESCAPE用法)-MySQL教程-Web开发者网...

    在SQl like语句中,比如 SELECT * FROM user WHERE username LIKE '%luchi%' SELECT * FROM user WHERE username L ...

  7. mysql status改变_mysql 配置详解mysql SHOW STATUS 详解

    1. back_log 指定MySQL可能的连接数量.当MySQL主线程在很短的时间内得到非常多的连接请求,该参数就起作用,之后主线程花些时间(尽管很短)检查连接并且启动一个新线程. back_log ...

  8. mysql键1键2_详解mysql基本操作详细(二)

    前言 本文类容 1.数据库的几大约束 2.表与表之间的关系 约束: 主键约束: 作用:为了保证数据的有效性和完整性 mysql中常用的约束:主键约束(primary key) 唯一约束(unique) ...

  9. 操作 mysql 不生成日志_详解MySQL的日志

    MySQL日志 MySQL的日志记录了MySQL的日常操作和错误信息,通过这些日志我们可以知道MySQL内部发生的事情,可以为MySQL的优化和管理提供必要的信息. MySQL的日志主要有:二进制日志 ...

  10. mysql删除数据库恢复_详解MySQL数据库恢复误删除数据

    血的教训,事发经过就不详述了.直接上操作步骤及恢复思路(友情提示:数据库的任何操作都要提前做好备份),以下是Mysql数据后的恢复过程: 1. 找到binlog 恢复数据的前提是必须开启Mysql的b ...

最新文章

  1. 前谷歌高管给初入职场新人的14条忠告
  2. matlab-矩阵应用
  3. 区块链世界中的IOTA:它是什么样的存在?
  4. boost::fusion::copy用法的测试程序
  5. securecrt使用_使用securecrt提升工作效率的十个技巧
  6. C++模版和C#泛型求同存异录(一)sizeof(T)
  7. python if 跳出_Python保留字简单释义
  8. xgboost 可视化与结果分析
  9. 用axure绘制PHP工作流程图,如何用Axure绘制高质量的业务流程图?
  10. 机器学习常见的优化算法
  11. DBConvert Studio - 数据库迁移和同步 - Crack
  12. Python3制作网易云音乐下载器!付费的你猜能下载吗!
  13. ActiveSync同步使用方法
  14. HTML和CSS小知识点笔记
  15. 乳清蛋白和支链氨基酸不得不说的关系
  16. 含8的数字的个数 (10分)
  17. 国外java_Java开发必知道的国外10大网站
  18. html语言教程教案,HTML语言与网页制作教案.doc
  19. java 实现office转换pdf
  20. Oracle操作语句(PL/SQL)创建表空间:第 1 行出现错误: ORA-01119: 创建数据库文件时出错 ORA-27040: 文件创建错误, 无法创建文件OSD-04002: 无法打开文件

热门文章

  1. 前端学习(1540):案例分析
  2. spring学习(37):注入list类型
  3. 第六十八期:做中台找死,不做中台等死?
  4. 第四十六期:最近程序员频繁被抓,如何避免面向监狱编程?!
  5. 玩转oracle 11g(9):crud操作(亲测)
  6. java学习(44):引用参数传递
  7. ftp文档服务器设置,ftp服务器基本设置
  8. 文件上传命令rz和下载命令sz的安装
  9. stylus之运算符(Operators)
  10. java派生类_我可以使派生类从Java的基类继承派生成员...