码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • mongoDB的三种基础备份方法


    目录

    一、快照

    二、数据文件拷贝

    三、mongodump与mongorestore


    一、快照

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

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

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

    缺点也比较明显:

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

    2、无法实现增量备份,理由很简单,其无法确定数据的变动,无法明确这个时间点的数据与上一次备份时间的的数据具体发生了哪些变化。

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

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

    二、数据文件拷贝

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

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

    2、恢复时需要停止mongod实例。

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

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

    三、mongodump与mongorestore

            这两个都是mongo集成的备份与恢复工具,功能也是十分的强大。

            使用mongodump可以将数据库数据导出为二进制的bson格式的文件。并且支持collection粒度的备份。

            mongorestore是配合mongodump使用的,只要是mongodump导出的数据都可以进行回复。

            而且配合mongoDB副本集模式下开启的oplog功能,可以实现增量备份。

            他俩的唯一缺点就是性能太低了,远不如上面两种方法。github上面有go语言实现的源码,若精力充足可以阅读并进行优化。

            由于篇幅的问题(懒),具体的使用方法见下面的链接mongodump — MongoDB Manualhttps://www.mongodb.com/docs/v4.4/reference/program/mongodump/
    mongorestore — MongoDB Manualhttps://www.mongodb.com/docs/v4.4/reference/program/mongorestore/

  • 相关阅读:
    Windows使用scp上传文件到linux服务器
    debian11 安装后必备配置
    Elasticsearch数据操作原理
    酷开科技丨酷开系统智慧中心,解锁AI智能家居生活的无限可能
    CVE-2022-22965:Spring远程代码执行漏洞
    从0到1带你搭建一个vue3.0项目(vue-cli脚手架版)
    批量插入,部分参数为null,报sql语法错误解决方案
    【9-1】实验——Neo4j实战操作
    电子学会C/C++编程等级考试2022年09月(一级)真题解析
    抖音矩阵系统,抖音矩阵系统源码,抖音SEO源码独立部署。
  • 原文地址:https://blog.csdn.net/qq_37437983/article/details/125452608
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号