【问题标题】:Inserting data to MongoDB Atlas using Mongoose and SRV connection string使用 Mongoose 和 SRV 连接字符串将数据插入 MongoDB Atlas
【发布时间】:2018-08-20 23:11:42
【问题描述】:

我在 MongoDB Atlas 中创建了一个集群,但似乎无法向其中写入数据。

const uri = "mongodb+srv://myUser:myPass@myDB-4myav.mongodb.net/portfolio";

我有这个作为我要连接的uri,每次我尝试写入数据库时​​,我都会收到这个错误:

{ MongoError: 管理员未授权执行命令 { insert: “用户”,文档:[[{name Daniel} {_id ObjectIdHex("5aa6d7d6396deb25844ccb52")} {__v 0}]], 排序: false }

我已经读到我需要创建一个具有“root”角色的管理员用户,但是当我使用 mongo shell 连接到我的数据库并尝试创建它时,我得到了这个:

错误:无法添加用户:管理员未授权执行命令

所以基本上我没有可以写入我的数据库的用户。

我还尝试在 MongoDB Atlas 网站(当然对于我的集群)上创建一个具有所有可能角色的用户,然后通过 mongo shell 与之连接,但这也失败了。

总结一下:我在 MongoDB Atlas 上创建了一个新集群。如何向其写入数据?

提前致谢,如果我遗漏了一些简单而愚蠢的东西,请随时指出。

【问题讨论】:

  • 您需要通过 Atlas (docs.atlas.mongodb.com/security-add-mongodb-users) 管理用户,并创建一个具有“读取和写入任何数据库”角色的用户帐户(或使用高级选项获得更精细的权限)。
  • 我已经做到了。更妙的是,我还注册了所有可能的角色的帐户,但我仍然被拒绝。
  • 啊!该错误表明您的代码正在尝试将文档插入admin 数据库,该数据库是为用户和角色信息保留的系统数据库。在您的连接字符串中您打算使用portfolio,但srv 连接字符串不支持指定数据库,因此您需要在连接后更改为该数据库。有关解决方法,请参阅 github.com/Automattic/mongoose/issues/6106

标签: mongodb mongoose mongodb-atlas


【解决方案1】:

您需要在 Mongo Shell 中创建一个具有 root 角色的用户,

use admin
db.createUser(
{
   user: "admin",
   pwd: "password",
   roles: [ { role: "root", db: "admin" } ]
}
);
exit;

或者您需要通过图集添加新用户(请参阅下面的快照)

  1. 转到集群
  2. 点击安全
  3. 点击添加新用户
  4. 输入用户名
  5. 根据 SCRAM-SHA1 方法创建密码
  6. 选择角色地图集管理员
  7. 点击添加用户

创建用户后,转到Clusters-->OverView --> CONNECT

  1. 验证IP白名单
  2. 选择一种连接方式:
    • 与 Mongo Shell 连接(我正在选择)
    • 连接您的应用程序
    • 连接 MongoDB Compass

$ mongo "mongodb+srv://project-u-s3cgp.azure.mongodb.net/test" --username dbAdmin

MongoDB shell version v3.6.1

Enter password:

connecting to: mongodb+srv://project-u-s3cgp.azure.mongodb.net/test

.........
.........

MongoDB Enterprise project-U-shard-0:PRIMARY>db.user.insert({name:"Daniel"})
WriteResult({ "nInserted" : 1 })
MongoDB Enterprise O2Ci-U-shard-0:PRIMARY>

我希望,您可以在创建 root 用户后插入记录。

谢谢, 卡西克

【讨论】:

  • 显然我的代码试图写入“admin”数据库,但它不起作用,所以上面的好人解释说这是一个常见的问题,有一个巧妙的解决方法。尽管如此,还是感谢您的帮助!
【解决方案2】:

{ MongoError: 管理员未授权执行命令 { insert: "users", 文档: [[{name Daniel} {_id ObjectIdHex("5aa6d7d6396deb25844ccb52")} {__v 0}]], ordered: false }

此错误表明您的代码正在尝试将文档插入admin 数据库,这是一个为用户和角色信息保留的系统数据库。

在您的连接字符串中,您打算使用portfolio 数据库。但是,srv 连接字符串格式不支持指定数据库,因此您的选项被忽略并使用默认数据库 admin。连接后需要选择portfolio数据库。

Mongoose 问题跟踪器 (GitHub issue #6106) 中也报告了这一点,用户在其中发布了您可以调整的解决方法:

mongoose.connection.on('connected', function() {
    // Hack the database back to the right one, because when using mongodb+srv as protocol.
    if (mongoose.connection.client.s.url.startsWith('mongodb+srv')) {
        mongoose.connection.db = mongoose.connection.client.db('portfolio');
    }
    console.log('Connection to MongoDB established.')
});
mongoose.connect(...);

我已经读到我需要创建一个具有“root”角色的管理员用户,但是当我使用 mongo shell 连接到我的数据库并尝试创建它时,我得到了这个:

您需要manage users via MongoDB Atlas 而不是mongo shell。您可以创建一个具有“读取和写入任何数据库”角色的用户帐户(或使用高级选项更精细的权限)。

【讨论】:

  • 非常感谢!解决方法是我不知道的事情,我一生都找不到它。非常感谢!
猜你喜欢
  • 2019-03-14
  • 1970-01-01
  • 2019-03-06
  • 2019-10-23
  • 1970-01-01
  • 2020-02-22
  • 2020-07-25
  • 2017-09-09
  • 1970-01-01
相关资源
最近更新 更多