开发者社区> 问答> 正文

MongoDB的备份方式有哪些?

MongoDB的备份方式有哪些?各位简要介绍一下。

展开
收起
落地花开啦 2016-02-05 16:13:30 3019 0
1 条回答
写回答
取消 提交回答
  • 喜欢技术,喜欢努力的人

    1. mogodump / mongorestore
    这两个命令将mongodb的数据dump为BSON格式,需要的时候可以恢复。这种方式作为小的数据库还适用。但如果是sharding或者几百G数据以上的话,就几乎不可用了。因为BSON极其占用空间。
    2. Slave Replication
    这是最适合和可靠的,适合生产环境。MongoDb支持master+多个slave。因此可以很方便的起一个slave来进行备份。但是需要注意的是如果数据量很大的话,如果是新建的slave,速度又没有保证的话,一定要调高 oplogSize 的大小,对于一个300G的数据库,可以调到60G以上。这样避免同步到中间出现oplogSize不足等异常。
    3. 关于增量热备份
    对于某些热衷单独文件备份的同志,也可以考虑使用“增量热”备份的方式作为最后的屏障。具体做法就是,最开始将某个slave暂时 shutdown,然后将数据库文件复制到另一个目录作为增量备份的起点。每次备份的时候,在这个目录上起一个slave, 使用–fastsync参数,同步完毕即可tar这个目录就可以了。
    这种方式的一个缺点就是如果备份周期的过长的话,空间浪费会非常大,尤其是频繁删除的情况下,目前1.6以前的版本对于删除的空间回收机制有bug。这个问题应该在1.6版本发布时候解决。
    要想回收这些空间需要repairDatabase,速度比较慢,不如直接从头clone一个新的db了。(其实Repair的过程也就是先clone然后copy回来)。
    综上所述, 最靠谱和安全的备份方式就是用mongodb自身的同步复制机制.
    最经典也最小的生产环境是:
    1 master + 2 slaves

    2019-07-17 18:37:53
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
开源数据库 MongoDB 专场 MongoDB疑难杂症分析及优化 立即下载
MongoDB多数据中心的方案选型之路 立即下载
饿了么高级架构师陈东明:MongoDB是如何逐步提高可靠性的 立即下载