最新消息:20210816 当前crifan.com域名已被污染,为防止失联,请关注(页面右下角的)公众号

【已解决】mongoimport/mongoexport和mongodump/mongorestore的区别

MongoDB crifan 5660浏览 0评论

折腾:

【已解决】同步导出在线Mongo中某个集合(表)到本地

期间,对于Mongo数据的导出和导入,看到很多帖子提到了:

  • mongodump

  • mongorestore

也有说用

  • mongoexport

  • mongoimport

后来在看:

mongoimport — MongoDB Manual

的期间,就看到官网有解释了。

而关于:

mongoimport,mongoexport

和:

mongodump,mongorestore

的区别,官网也说了:

不要把mongoimport,mongoexport用于 生产环境的备份

-》因为mongoimport,mongoexport只是导入导出JSON格式数据

-〉无法支持和保留所有的类型的数据

-〉原因是:Mongo内部完整的数据是用BSON格式去表示的,而JSON只是BSON的子集,所以有些数据格式,JSON无法表示出来

具体解释详见:

MongoDB Backup Methods — MongoDB Manual

【总结】

背景知识:

MongoDB内部数据保存用BSON

JSON是BSON的子集 -》 部分数据类型无法用JSON保存

-〉所以如果导出为JSON格式,可能会丢失部分复杂的数据类型的数据

mongoimport/mongoexport
mongodump/mongorestore
主要用途小规模的或部分的Mongo的数据的,测试期间的数据备份/恢复简单且高效的 小型的MongoDB的数据库的备份/恢复
导出格式JSONBSON
额外说明
导出数据时使用严格模式(strict mode representation=MongoDB Extended JSON
仅支持UTF-8编码的数据
不适合备份/恢复 大型MongoDB数据库
默认是不拷贝local这个(特殊的)数据库
经验/结论
不支持普通导出单个db的所有的collection
支持普通导出单个db的所有的collection
建议:普通的,简单的,数据的备份和恢复,都还是用mongodump/mongorestore这套工具

其他相关:

  • 如果是在线云平台部署的Mongo,备份/恢复可以使用:

    • MongoDB Atlas (Fully Managed MongoDB, hosted on AWS, Azure, and GCP | MongoDB)

  • 如果是replica sets,备份/恢复可以使用:MongoDB Cloud Manager or Ops Manager 

转载请注明:在路上 » 【已解决】mongoimport/mongoexport和mongodump/mongorestore的区别

发表我的评论
取消评论

表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
84 queries in 0.179 seconds, using 22.17MB memory