1、什么情况下会用到备份呢?

【1.1】灾难恢复

【1.2】单位审计:数据库在过去某一个点是什么样的

【1.3】跨机房灾备:异地备份

【1.4】认为的DDL或者DML语句,导致主从库的数据消失

【1.5】业务测试,构建测试库

2、备份的分类

  分为冷备份、温备份、热备份

【2.1】冷备份(离线备份:读写操作均中止)

  优点:设备投资较少,节省费用,对环境要求不高。

  缺点:恢复时间较长,一般要数天至1周,数据完整性与一致性比较差;

【2.2】温备份(只可以执行读操作)

  优点:设备投资较少,节省费用,对环境要求不高。

  缺点:恢复时间较长,一般要数天至1周,数据完整性与一致性比较差;

【2.3】热备份(读、写不受影响)

  优点:恢复时间短,一般几十分钟到数个小时,数据完整性与一致性最好,数据丢失可能性最小。

  缺点:设备投资大,费用高,对环境要求高,运维管理比较复杂。

【2.4】总结

 

根据主机和备机之间同步数据的程度,备份可以分为三种情况,分别为冷备份、暖备份和热备份。
  • 冷备份:也就是所谓的备份,备用服务器被配置用于接受主服务器的数据,当出故障时,手动将数据还原到主数据库,或是重新配置程序的连接字符串或权限来使得备份数据库上线。
  • 暖备份:主服务器数据会不停的将日志传送到备用服务器(间隔不定,可以是15分钟,30分钟,1分钟等等),在这方式下,主服务器到备份服务器通常是异步更新,所以不能保证主服务器和备份服务器数据一致。此外,该方案通常不会实现自动故障监测和故障转移。
  • 热备份:主服务器的数据自动在备份服务器上进行同步,大多数情况下都会包含自动的故障监测和故障转移,并且能够保证主服务器和备份服务器的数据一致性。

随着冷备份到暖备份到热备份,成本会直线上升。

3、备份的方式

  分为物理备份与逻辑备份2种

【3.1】物理备份(直接复制文件/目录)

  所谓的物理备份,就是把整个关于mysql数据库的相关目录都拷贝一份。

  物理备份产生的数据副本都是二进制文件,通常不可编辑,例如数据库的二进制日志;

  特点:

  (1)由数据库文件和目录组成,是mysql数据目录的全部或者部分

  (2)一般备份比逻辑备份快,因为纯属是文件复制,不用像逻辑备份那样需要做SQL转换

  (3)备份的粒度比逻辑备份小,因为是全文件复制了,当然比SQL要精确一些。

  (4)物理备份的文件不仅是数据库,还可以是数据库的日志,配置文件

  适用:适用于大数据量的备份,比如你有百G,TB以上。

  备份方法:

    (1)文件系统命令:cp/scp/tar/rsync;

    (2)Mysql备份软件,系统快照snapshot;

【3.2】逻辑备份(将数据以SQL方式导出至文本文件)

  特点:

  (1)逻辑备份通过查询数据库的信息进行备份

  (2)速度比较慢,因为获取了信息,然后组装成SQL语句,如果调用命令是远程还要把SQL语句远程传输

  (3)备份文件要比物理备份小

  (4)备份粒度只能到表

  (5)没有日志或者配置文件

  (6)备份文件是SQL语句,逻辑语句,相对而言可移植性好(比如跨OS)。

4、备份的模式

  一般分为3种,全备、差异备、增量备

【4.1】全备:备份所有数据

【4.2】差异备:备份自上一次全备到现在的数据

【4.3】增量备:备份自上一次全备/增量备到现在的数据

5、mysql一般备份的数据

【5.1】数据文件

【5.2】日志文件(比如事务日志、二进制日志)

【5.3】存储过程,存储函数,触发器

【5.4】配置文件(很重要,各个配置文件都要备份)

【5.5】用于实现数据库备份的脚本

6、mysql常用备份工具

【6.1】mysqldump(单线程)/mysqlpump(多线程,5.7+以后才有)

  是一种逻辑备份工具,支持完全、部分备份。InnoDB热备,MyIsam温备;

【6.2】mydumper开源,是mysqldump的一个衍生,速度在两者之间。(5.7以后不要用了)

【6.3】cp/tar :物理备份。lvm2快照(请求一个全局锁),之后立即释放,达到几乎热备的效。果。

  注意:不能仅备份数据文件,要同事备份事务日志;

  前提:要求数据文件和事务日志位于同一个逻辑卷;

【6.4】innobackup【收费】/xtrabackup【免费】

  由Percona提供,开源工具,支持Innodb做热备份,物理备份工具;

  完全备份、部分备份;完全备份、增量备份;完全备份、差异备份;

【6.5】mysqlhotcopy(已淘汰):物理备份工具,但只支持myIsam,基本属于冷备份,物理备份,速度较快

【6.6】主从复制

【6.7】官方mysql enterprise backup 备份软件,收费

【6.8】其他第三方工具、厂家

(4.2)mysql备份还原——备份概述的更多相关文章

  1. 黄聪:Mysql数据库还原备份提示MySQL server has gone away 的解决方法(备份文件数据过大)

    使用mysql做数据库还原的时候,由于有些数据很大,会出现这样的错误:The MySQL Server returned this Error:MySQL Error Nr. MySQL server ...

  2. (4.4)mysql备份还原——备份存储容灾基础知识

    存储知识 1.为什么需要存储,存储一般解决哪些问题? 容量.速度.易于管理.安全(容灾与备份).可扩展性 2.存储发展历史 [2.1]大型机 [2.2]c/s结构(客户端->服务器) [2.3] ...

  3. mysqldump工具实现mysql数据库的备份还原

    简介 冷.温.热备份 冷备:读写操作均不可进行 温备:读操作可执行:但写操作不可执行 热备:读写操作均可执行 MyISAM:温备,不支持热备 InnoDB:都支持 不管是热备还原还是冷备还原,还原时都 ...

  4. 基于xtrabackup实现mysql备份还原

    简介 Xtrabackup2.2版之前包括4个可执行文件: innobackupex: Perl 脚本 xtrabackup: C/C++ 编译的二进制 xbstream: 支持并发写的流文件格式 x ...

  5. Gitlab 备份还原/迁移

    Gitlab 备份还原 备份数据:通过命令进行备份操作 gitlab-rake gitlab:backup:create ... [DISABLED] Creating backup archive: ...

  6. MySQL/MariaDB数据库的mysqldump工具备份还原实战

    MySQL/MariaDB数据库的mysqldump工具备份还原实战 作者:尹正杰  版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.mysqldump概述 1>.逻辑备份工具 mysq ...

  7. mysql 命令行还原备份数据库

    通常数据库还原备份可以通过navicat等数据库管理工具进行,只需要简单的导出导入就行了,但遇到有索引外键的数据库,数据库管理工具运行.sql文件会报错,这时候可以尝试命令行导入,亲测可以成功 MyS ...

  8. 如何用SQL语句实现Mysql数据库的备份与还原

    以前一直做android客户端的项目,根本没有开发asp.net mvc的开发,现阶段做了一个模块,参数设置,以及数据库的备份与还原.其需求如下: 参数设置 本项参数设置为对自动数据备份进行设置,管理 ...

  9. 通过innobackupex实现对MySQL的增量备份与还原

    备份 增量备份是基于完整备份的,所以我们需要先做一次完整备份: innobackupex --password=test /backup/ 备注:test是我的MySQL服务的root用户的密码,/b ...

随机推荐

  1. swoole 定时器

    timer.php <?php //创建websocket服务器对象,监听0.0.0.0:9502端口 $ws = ); swoole_timer_tick(, function ($timer ...

  2. [Bayes] openBUGS: this is not the annoying bugs in programming

    Bayesian inference Using Gibbs Sampling 允许用户指定复杂的多层模型,并可使用MCMC算法来估计模型中的未知参数. We use DAGs to specify ...

  3. osx 10.11 一键制作U盘傻瓜工具最新版 无需任何命令

    osx 10.11 最新版U盘制作工具   无需任何命令   纯傻瓜式  !!!只要把app下载下来放在应用程序  鼠标点点就可以做了... 下载地址:http://diskmakerx.com/do ...

  4. Git-简单的利用SourceTree提交代码

    解决办法: 小编也是新手,所以在使用SourceTree上面花了不少时间,好在简单的拉去远程代码,同步本地仓库代码搞定了.下面是步骤: 1.我们先去下载一个SourceTree然后打开. 2.下一步, ...

  5. ngxs 状态管理器

    官网文档 ng6,rxjs6.0.0,ngxs3.0.1 λ ng new ngxs --style=styl --routing --skip-install λ cd ngxs λ yarn λ ...

  6. Android性能测试--内存

    前言: 近阶段都在探索android性能测试方面的东西,其中一个很重要的指标就是内存.对于内存,主要是一些gc是不是及时,或者说一些引用有没有及时释放,有没有导致oom或者内存持续增加导致卡顿,有没有 ...

  7. 正则表达式、re模块

    正则表达式 一说规则我已经知道你很晕了,现在就让我们先来看一些实际的应用.在线测试工具 http://tool.chinaz.com/regex/ 正则表达式是用来匹配字符串非常强大的工具,在其他编程 ...

  8. ERP项目实施记录08

    已经和软件商签订报价软件合同过去了2周,五一过后会有测试版本出来. 在整个接触过程中感觉开发方思路就是照葫芦画瓢,拿着这边的表单尽量往软件里搬,没有理清思路又急着赶进度:另外又要兼顾他们现有的&quo ...

  9. {前端CSS} 语法 Css的几种引入方式 css选择器 选择器的优先级 CSS属性相关 背景属性 边框 CSS盒子模型 清除浮动 overflow溢出属性  定位(position)z-index

    前端CSS CSS介绍 CSS(Cascading Style Sheet,层叠样式表)定义如何显示HTML元素,给HTML设置样式,让它更加美观. 当浏览器读到一个样式表,它就会按照这个样式表来对文 ...

  10. 关于html中input组件间空隙的去除

    有空隙的时候的代码是这样的: <input type="text" name="search" title="请输入要搜索的内容" s ...