mongodb用户认证
2016-05-20 14:40
435 查看
下载的mongodb3.2.1版本,当使用--auth 参数命令行开启mongodb用户认证时遇到很多问题,现总结如下:
(百度上搜到的基本都是老版本的,看到db.addUser的就是,请忽略)3.0之后,mongodb加入了SCRAM-SHA-1校验方式,需要第三方工具配合进行验证,下面给出具体解决办法:
首先关闭认证,修改system.version文档里面的authSchema版本为3,初始安装时候应该是5,命令行如下:
> use admin
switched to db admin
> var schema = db.system.version.findOne({"_id" : "authSchema"})
> schema.currentVersion = 3
3
> db.system.version.save(schema)
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
原因是原来创建的用户已经使用了SCRAM-SHA-1认证方式
> use admin
switched to db admin
> db.system.users.find()
[...]
{ "_id" : "test.zxx", "user" : "zxx", "db" : "test", "credentials" : { "SCRAM-SHA-1" : { "iterationCount" : 10000, "salt" : "XXXXXXXXXXXXXXXXXXXXXXXX", "storedKey" : "XXXXXXXXXXXXXXXXXXXXXXXXXXX", "serverKey" : "XXXXXXXXXXXXXXXXXXXXXXXXXXX" } }, "roles" : [ { "role" : "dbOwner", "db" : "test" } ] }
解决方式就是删除刚刚创建的用户,重新重建即可:
> use userdb
switched to db userdb
> db.dropUser("zxx")
true
>db.createUser({user:'zxx',pwd:'123456',roles:[{role:'dbOwner',db:'test'}]})
然后关闭服务器,开启认证,重启服务器,用robomongo连接,一切OK
相关文章推荐
- Mongodb用户和认证 权限总结
- mongodb 用户认证
- mongodb的用户认证
- Mongodb用户和认证 权限总结
- MongoDB 开启安全认证及创建用户
- MongoDB 用户认证
- 简单的给mongodb添加用户和认证
- MongoDB增加用户认证:增加用户、删除用户、修改用户密码、读写权限、只读权限
- MongoDB增加用户认证: 增加用户、删除用户、修改用户密码、读写权限、只读权限
- mongoDB添加用户认证及简单的配置说明
- MongoDB用户认证
- mongodb的用户认证
- mongodb 3.x用户认证
- MongoDB的用户、认证和权限
- MongoDB:用户认证
- mongodb 3.2 集群认证及创建用户
- MongoDB学习04之用户认证
- Mongodb用户和认证 权限总结
- mongodb开启用户认证,reactivemongo开启认证
- MongoDB增加用户认证:增加用户、删除用户、修改用户密码、读写权限、只读权限