目录

一、物理备份-快照

二、物理备份-数据文件拷贝

三、逻辑备份-mongodump


一、物理备份-快照

使用快照进行备份是最常用的一种方法,很多企业的备份产品都是基于此(爱数、commvault等)。下面以爱数的备份原理图为例。

  1. 管理控制台启动备份任务。
  2. 控制台向各物理客户端的发送备份命令,各个客户端查找本机节点是否为 Primary(主)节点,如果不是 Primary(主)节点,该节点备份任务结束。
  3. Primary(主)节点所在客户端获取 MongoDB 数据目录所在的文件系统,为该文件系统创建快照卷并挂载到一个临时目录。
  4. 客户端传输该临时目录的数据到存储服务器。
  5. 客户端完成备份,上报任务备份情况到管理控制台,结束整个备份任务。

该方法的主要有点是速度快,使用方便。

缺点也比较明显:

1、副本集内所有的主机都必须保留  > 500MB 的VG卷空间。虽然只有主节点进行备份操作,但在副本集架构下所有节点都有可能成为主节点。

2、无法实现增量备份,理由很简单,其无法确定数据的变动,无法明确这个时间点的数据与上一次备份时间的的数据具体发生了哪些变化(当然一些牛逼的公司确实是做出来了,比如阿里)。

3、只能对mongod实例下的所有数据库进行集体备份,无法实现细粒度的数据库备份。

4、快照的数据恢复也是比较繁琐的,特别是异地恢复。

二、物理备份-数据文件拷贝

这种方法也是比较简单直接的,直接将mongoDB数据目录下所有的数据拷贝出来。但有几点需要注意。

1、拷贝操作发生前需要对数据库进行加锁操作。加锁后无法对数据库进行写操作,可能会影响正常业务。拷贝完成后记得解锁。

2、恢复时主机的环境与备份时需要尽可能的一致,包括数据库版本、操作系统等等。而且需要停止mongod实例。

这种方法的缺点与快照类似。具体的操作,示例如下所示:

# 进入mongo shell
db.fsyncLock()# 退回到linux shell
# 将mongo的dbpath全部拷贝到缓存目录
cp -R /var/lib/mongo/* /backup# 进入mongo shell
db.fsyncUnlock()

三、逻辑备份-mongodump

mongodump是mongo集成的备份与恢复工具,功能也是十分的强大,其与mongorestore配合可以完成大多数场景的数据备份。不过在使用之前需要仔细的阅读相关文档,并实际操作测试其功能特性。而且需要注意,随着不同数据库的版本迭代,该工具的一些功能也会随之变化。

使用mongodump可以对数据库进行全量备份与增量备份,这个可以在网上搜到很多脚本例子。但其还是存在一些功能缺陷,不过好在其在github上开放了源码,用户可以基于其源码根据自己的需求进行修改。

他俩的还一个缺点就是性能太低了,远不如物理备份。所以很多厂商在做产品时都不会考虑它。

由于篇幅的问题(懒),该工具的具体的使用方法见下面的链接mongodump — MongoDB Manual
mongorestore — MongoDB Manual

mongoDB的三种基础备份方法相关推荐

  1. mongo学习笔记四:Mongodb的三种集群(Replica Set)

    Replica Set    中文翻译叫做副本集,不过我并不喜欢把英文翻译成中文,总是感觉怪怪的.其实简单来说就是集群当中包含了多份数据,保证主节点挂掉了,备节点能继续提供数据服务,提供的前提就是数据 ...

  2. html引入外部css_CSS 三种基础选择器

    本节我们来学习 CSS 中的选择器,选择器是 CSS 里面一个很重要的概念,HTML 中的所有标签样式,都是通过不同的 CSS 选择器进行控制的.我们只需要通过选择器,就可以对不同的 HTML 标签进 ...

  3. uniapp怎么引入css_CSS 三种基础选择器

    本节我们来学习 CSS 中的选择器,选择器是 CSS 里面一个很重要的概念,HTML 中的所有标签样式,都是通过不同的 CSS 选择器进行控制的.我们只需要通过选择器,就可以对不同的 HTML 标签进 ...

  4. ipad使用计算机的图片大全,三种方式备份 iPad 照片

    三种方式备份 iPad 照片 是一个重要的备份照片从 iPad.这是因为这些照片记录了幸福和悲伤在你的生活.为了让他们的肉体,备份是一个不错的选择.照片通常捕获大量的存储,可能会迫使你有没有足够的空间 ...

  5. 【小白学习keras教程】十、三种Model Selection方法:k-fold cross-validation,GridSearchCV和RandomizedSearchCV

    @Author:Runsen Model Selection是划分训练集和测试集的手段,下面总结了三种Model Selection方法. k-fold cross-validation using ...

  6. Python实现二叉树的三种深度遍历方法!

    python代码实现了二叉树,这次将会实现二叉树的几种遍历方法,来更好的解析二叉树的结构特点.分别是一种广度遍历,和三种深度遍历方法:先序遍历,中序遍历,后序遍历.下面是代码实现: 1.先序遍历 遍历 ...

  7. php调用mysql库_PHP调用三种数据库的方法(1)

    PHP调用三种数据库的方法(1) 更新时间:2006年10月09日 00:00:00   作者: MySQL是一个小巧灵珑的数据库服务器软件,对于中.小型应用系统是非常理想的.除了支持标准的ANSI ...

  8. 实现两数 交换的三种不同编程方法。

    第一种 即常规方法 借助第三变量 int a = 5,b = 3,c; c = a; a = b; b = c; 第二种 不借助第三变量 int a=5,b=3,c; a = a+b;    //(缺 ...

  9. 常用的分隔符有哪三种_掌握这三种调漂方法,你想怎么钓就怎么钓,再也不用求人...

    调漂对于刚学钓鱼的钓友来说是一件非常头痛的事情,每次钓鱼大部分时间都浪费在调漂上,总是感觉调不好,不是灵了就是钝了!那么问题到底出在哪呢?今天就和大家分享三种针对悬坠钓的调漂方法,看懂弄明白了,再也不 ...

最新文章

  1. CV:计算机视觉基础之图像存储到计算机的原理daiding
  2. 浙大计算机专业分数线,被浙江大学提前批的冷门专业录取,后悔没选计算机专业:可惜分数...
  3. socket技术难点
  4. [zz]c++ list sort方法
  5. 文献记录(part10)--BARTMAP-A viable structure for biclustering
  6. 字节字符区别Java_【JAVA基础】字符数组与字节数组的区别
  7. leetcode LCP 19. 秋叶收藏集(dp)
  8. 程序员面试金典 - 面试题 05.02. 二进制数转字符串(浮点型 转 二进制小数,乘2取整)
  9. Hive 内置函数权威指南,操作大全
  10. Android笔记 显式意图demo
  11. Java 线程池的复用原理
  12. 如何搭建一个WAMP环境
  13. mac电脑安卓开发环境搭建
  14. 【重拾FPGA】三段式状态机的路口红绿灯
  15. oracle数据库常用操作语句大全,Oracle 数据库常用操作语句大全
  16. 【C语言】输出华氏-摄氏温度转换表
  17. 北京迷笛音乐节阵容、北京草莓音乐节阵容
  18. tomcat服务器拒绝访问文件,tomcat拒绝访问特定文件
  19. win10系统ipv6服务器地址,win10系统查看电脑ipv6地址的操作方法
  20. 备份数据库 并发送到邮箱

热门文章

  1. linux系统的6000端口是什么,Linux操作系统有哪些常用端口?
  2. 第七届全国大学生工程训练大赛智能+赛道生活垃圾分类垃圾训练步骤(win10+yolov4-tiny)
  3. Docker Compose的网络设置
  4. c语言中的sched头文件,使用sched库完成周期定时任务
  5. Git是怎样生成diff的:Myers算法
  6. 浅谈五种常用的特征选择方法
  7. python分析出nba球员的位置_Python告诉你NBA球星都喜欢在哪个位置出手?
  8. 微信登录失败,redirect_uri域名与后台配置不一致,错误码:10003
  9. 1AE4混合电路耳放
  10. 基于JavaSwing的简单的动作类游戏