mongodb 认证方式(version:3.0.4)


之前一直在本机上跑,前段时间把后台架到云服务器上了,在settings里加上了username和password,希望同步的时候修改一下settings就能在本地测试。
 
因为云服务器端数据库连接需要验证,于是在本地也打算加上身份验证,而mongodb默认是没有验证的。
 
在网上搜索了一下,方法都比较旧,主要是在本地的mongodb中新增一个user:
进入mongodb下的bin
mongodb $ cd bin

不开启验证的方式启动mongodb

bin $ ./mongod -dbpath ../blog
输入mongo命令,进入test数据库
bin $ ./mongo
添加admin用户
1 use admin
2 db.createUser({
3      user:'admin',
4      pwd:'admin',
5      roles:[{role:'userAdminAnyDatabase',db:'admin'}]
6 })
切换到我的数据库(blog 为我的数据库名称),在我的数据库下创建用户
1 use blog
2 db.createUser({
3      user:'testuser',
4      pwd:'test',
5      roles:[{role:'dbOwner',db:'blog'}]
6 })
重启服务器,开启验证
bin $ ./mongod -dbpath ../blog --auth
使用Robomongo登陆,显示Authentication Failed,查看服务器日志:
2015-08-31T17:39:46.416+0800 I ACCESS   [conn46] Failed to authenticate testuser@blog with mechanism MONGODB-CR: AuthenticationFailed MONGODB-CR credentials missing in the user document
 
查看文档,发现是因为mongodb验证方式改变,加入了 (SCRAM)SHA-1
在mongo里将刚创建的用户删除
use blog
db.dropUser('testuser'
关闭验证重启数据库
在mongo里修改system.version文档里面的authSchema版本为3(旧版本)
1 use admin
2 db.system.version.update({'_id':'authSchema'},{$set:{'currentVersion':3}})
3 db.system.version.find()
可以看到:{ "_id" : "authSchema", "currentVersion" : 3 }
 
删除之前创建的用户,重新创建用户(这一次使用验证方式为MONGODB-CR)
1 use blog
2 db.dropUser('testuser')
3 db.createUser({
4      user:'testuser',
5      pwd:'test',
6      roles:[{role:'dbOwner',db:'blog'}]
7 })

 

 这一次可以用Robomongo成功登陆~

 

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM