折腾:
期间,对于Mongo数据的导出和导入,看到很多帖子提到了:
mongodump
mongorestore
也有说用
mongoexport
mongoimport
的
后来在看:
的期间,就看到官网有解释了。
而关于:
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的数据库的备份/恢复 |
导出格式 | JSON | BSON |
额外说明 | 导出数据时使用严格模式(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的区别