如何修改MongoDB3.0的数据库认证机制

修改需求:MongoDB3.0当前认证机制为SCRAM-SHA-1,需要改为老的认证机制MONGODB-CR

方法如下:
> use admin
switched to db admin

> db.system.version.findOne({"_id" : "authSchema"})
{ "_id" : "authSchema", "currentVersion" : 5 }
currentVersion为5则表示当前数据库的认证机制是SCRAM-SHA-1,需要改成MONGODB-CR,currentVersion的值为3

>  var schema = db.system.version.findOne({"_id" : "authSchema"})
> schema.currentVersion = 3
3
> db.system.version.save(schema)
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })

> db.system.version.find()
{ "_id" : "authSchema", "currentVersion" : 3 }
在这表示已经修改成功了。

创建数据库用户
> use test
> db.createUser({ user: 'test', pwd: 'test123', roles: [ { role: "readWrite", db: "test" } ] });
Successfully added user: {
    "user" : "test",
    "roles" : [
        {
            "role" : "userAdminAnyDatabase",
            "db" : "admin"
        }
    ]


查看认证方式:
> use admin
> db.system.users.find()
{ "_id" : "admin.admin", "user" : "admin", "db" : "admin", "credentials" : { "SCRAM-SHA-1" : { "iterationCount" : 10000, "salt" : "kAyNTjjA56SjKNB+voW/ow==", "storedKey" : "S0QMFvrojLTl4fYN4zz6HL3rlRc=", "serverKey" : "m0eym4YYQikIufcR8JxcIRfdDrg=" } }, "roles" : [ { "role" : "userAdminAnyDatabase", "db" : "admin" } ] }
{ "_id" : "test.test", "user" : "test", "db" : "test", "credentials" : { "MONGODB-CR" : "cf75a14725e3655983a84ea5f5b25438" }, "roles" : [ { "role" : "readWrite", "db" : "test" } ] }

见credentials字样,发现test用户的认证方式为MONGODB-CR,至此,认证机制方式修改完毕

PS:MONGODB-CR为2.6版本默认认证机制,php-mongo扩展使用的是2.6版本的认证,3.0以上的认证无法连接,版本不匹配。

上面的更改方式执行需要先在admin创建用户,不然会报错

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值