mongodb 认证方式(version:3.0.4)

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

不开启验证的方式启动mongodbmongodb

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成功登录~数据库

相关文章
相关标签/搜索