当前位置:网站首页>mongoDB的三种基础备份方法
mongoDB的三种基础备份方法
2022-06-26 19:21:00 【我要出家当道士】
目录
一、快照
使用快照进行备份是最常用的一种方法,很多企业的备份产品都是基于此(爱数、commvault等)。下面以爱数的备份原理图为例。

- 管理控制台启动备份任务。
- 控制台向各物理客户端的发送备份命令,各个客户端查找本机节点是否为 Primary(主)节点,如果不是 Primary(主)节点,该节点备份任务结束。
- Primary(主)节点所在客户端获取 MongoDB 数据目录所在的文件系统,为该文件系统创建快照卷并挂载到一个临时目录。
- 客户端传输该临时目录的数据到存储服务器。
- 客户端完成备份,上报任务备份情况到管理控制台,结束整个备份任务。
该方法的主要有点是速度快,使用方便。
缺点也比较明显:
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与mongorestore
这两个都是mongo集成的备份与恢复工具,功能也是十分的强大。
使用mongodump可以将数据库数据导出为二进制的bson格式的文件。并且支持collection粒度的备份。
mongorestore是配合mongodump使用的,只要是mongodump导出的数据都可以进行回复。
而且配合mongoDB副本集模式下开启的oplog功能,可以实现增量备份。
他俩的唯一缺点就是性能太低了,远不如上面两种方法。github上面有go语言实现的源码,若精力充足可以阅读并进行优化。
由于篇幅的问题(懒),具体的使用方法见下面的链接mongodump — MongoDB Manual
https://www.mongodb.com/docs/v4.4/reference/program/mongodump/
mongorestore — MongoDB Manual
https://www.mongodb.com/docs/v4.4/reference/program/mongorestore/
边栏推荐
- Solidity - contract inheritance sub contract contains constructor errors and one contract calls the view function of another contract to charge gas fees
- 字符串String转换为jsonArray并解析
- 转:实事求是
- SSO微服务工程中用户行为日志的记录
- 2022/02/14 line generation
- Web resource preloading - production environment practice
- Redis Basics
- 【Kubernetes】Kubernetes 原理剖析与实战应用(更新中)
- 抖音实战~分享模块~生成短视频二维码
- Image binarization
猜你喜欢
随机推荐
DAPP丨LP单双币流动性质押挖矿系统开发原理分析及源码
微服务架构
一些基本错误
Handwritten numeral recognition based on tensorflow
Kubernetes 资源拓扑感知调度优化
Project practice 5: build elk log collection system
Solidity - contract inheritance sub contract contains constructor errors and one contract calls the view function of another contract to charge gas fees
数据库范式和主码的选择
Nftgamefi chain game system development detailed solution - chain game system development principle analysis
ROS query topic specific content common instructions
Microservice architecture
(树) 树状数组
Yujun product methodology
关于Qt数据库开发的一些冷知识
8VC Venture Cup 2017 - Final Round C. Nikita and stack
Micro service single sign on system (SSO)
物联网协议的王者:MQTT
Project practice 4: user login and token access verification (reids+jwt)
wm_ Concat() and group_ Concat() function
Unit test of boot









