【发布时间】:2019-02-22 16:05:36
【问题描述】:
我正在尝试将数据从 MongoDB 还原到 Azure Cosmos DB 模拟器,以测试我的应用程序。我最初使用数据导入工具,但在阅读文档后意识到这是用于 Cosmos DB 的 SQL API,而我想使用 MongoDB API。
我使用命令行成功地将我的数据从 Mongo 导出到 json 文件:
D:\MongoDb\bin>mongoexport.exe --db Vehicles --collection Cars --out C:\Temp\Cars.json
2018-09-18T10:02:21.210-0400 connected to: localhost
2018-09-18T10:02:21.212-0400 exported 100 records
然后我尝试使用以下命令将其导入 Azure Cosmos DB 模拟器
D:\MongoDb\bin> mongoimport.exe --host localhost:10255 -u admin -p C2y6yDjf5/R+ob0N8A7Cgv30VRDJIWEHLM+4QDU5DE2nQ9nDuVTqobD4b8mGGyPMbIZnqyMsEcaGQy67XIw/Jw== --ssl --sslAllowInvalidCertificates --db Vehicles --collection Cars --type json --file "C:\Temp\Cars.json"
但是我收到以下错误:
2018-09-18T11:00:38.829-0400 Failed: error connecting to db server: Database Account admin does not exist
ActivityId: ada5953a-0000-0000-0000-000000000000, Microsoft.Azure.Documents.Common/1.22.0.0
2018-09-18T11:00:38.830-0400 imported 0 documents
我在 Azure Cosmos DB 模拟器中创建了一个名为 Vehicles with a Cars 集合的数据库,因此不确定我做错了什么 - 或者 Azure Cosmos 模拟器不能用于我正在尝试的事情吗?
我尝试在命令行脚本中将管理员更改为 Vehicles,但得到了同样的错误。
在 Azure Cosmos DB 模拟器中,这是我的 Mongo 连接字符串,我从中提取详细信息以进行导入
mongodb://localhost:C2y6yDjf5/R+ob0N8A7Cgv30VRDJIWEHLM+4QDU5DE2nQ9nDuVTqobD4b8mGGyPMbIZnqyMsEcaGQy67XIw/Jw==@localhost:10255/admin?ssl=true
理想情况下,我想让模拟器运行以在本地进行测试
【问题讨论】:
-
你试过用
localhost作为用户名吗?我的意思是。在 mongiimport.exe 字符串中使用-u localhost而不是-u admin。 -
是的 - 我刚试过@localhost:10255/admin
-
不,没有端口。只是本地主机。像这样:
D:\MongoDb\bin> mongoimport.exe --host localhost:10255 -u localhost -p C2y6yDjf5/R+ob0N8A7Cgv30VRDJIWEHLM+4QDU5DE2nQ9nDuVTqobD4b8mGGyPMbIZnqyMsEcaGQy67XIw/Jw== --ssl --sslAllowInvalidCertificates --db Vehicles --collection Cars --type json --file "C:\Temp\Cars.json" -
@NickChapsas = 只是本地主机工作 - 干杯....再次:) :)
-
没问题 :) 我添加了答案。
标签: mongodb azure azure-cosmosdb azure-cosmosdb-mongoapi