我有几个数据库,不想为每个数据库创建单独的用户帐户. MongoDB支持使用另一个数据库中定义的帐户验证对数据库的访问权限的概念,但语法示例很难得到.
当我终于弄明白时,我即将发布一个问题.这是为了以防万一
解决方法
这是
mongodb,mongoose,节点设置的语法.
>从mongo shell在admin数据库中创建数据库用户
使用管理员
db.addUser({user:“mydbuser”,pwd:“mypassword”,roles:[]})
>创建数据库并添加用户 – userSource指示该用户
凭据在管理数据库中定义
使用mydb
db.addUser({user:“mydbuser”,userSource:“admin”,roles:[“readWrite”,“dbAdmin”]})
>在mongoose连接字符串中指定auth参数
var myDB = mongoose.createConnection(“mongodb:// mydbuser:mypassword @ myipaddress:27017 / mydb”,{auth:{authdb:“admin”}});
选项{auth:…}是指定必须针对admin db对用户帐户进行身份验证的选项.
>类似于从mongo shell连接到数据库
mongo myipaddr:27017 / mydb -u“mydbuser”-p“mypassword”
注意:用户“mydbuser”只对mydb具有读/写和管理访问权限.您可以找到有关用户权限here的更多信息.该方案的更完整示例是here