我设置了带有身份验证的副本集。我使用了本教程。我设置了密钥文件,管理员用户和其他用户。一切正常-匿名访问已禁用,我可以登录
$ mongo
MongoDB shell version: 2.6.1
connecting to: test
Error while trying to show server startup warnings: not authorized on admin to execute command { getLog: "startupWarnings" }
rs0:PRIMARY> use admin
switched to db admin
rs0:PRIMARY> db.auth("USERNAME","PASSWORD")
1
rs0:PRIMARY>
使用我创建的用户的凭据。
但是我无法从命令行登录
$ mongo -u 'USERNAME' -p 'PASSWORD'
MongoDB shell version: 2.6.1
connecting to: test
2014-05-18T14:23:47.324+0200 Error: 18 { ok: 0.0, errmsg: "auth failed", code: 18 } at src/mongo/shell/db.js:1210
exception: login failed
使用相同的凭据。在文档中或此处没有找到任何有用的信息。
在您的示例中执行的外壳内身份验证是针对admin数据库的。上面发布的命令行未指定数据库,因此正在针对默认数据库test进行身份验证。尝试使用此命令通过命令行对admin db进行身份验证:
mongo admin -u 'USERNAME' -p 'PASSWORD'
如果服务器不在本地主机上,则可以使用以下命令:
mongo your_host_name:your_port/admin -u 'USERNAME' -p 'PASSWORD'
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句