首页 > 数据库 > MongoDB > 正文

浅析MongoDB用户管理

2020-03-14 13:25:35
字体:
来源:转载
供稿:网友

mongodb在2.4最新版本中对用户权限管理做了全新的调整,把权限细化了,增强了安全性,越来越像mysql的权限管理了。废话少说,我们来详细看下吧

1. 创建一个超级用户

 

 
  1. use admin 
  2. db.createUser( 
  3. user: "adminUserName"
  4. pwd: "userPassword"
  5. roles: 
  6. roles: "userAdminAnyDatabase"
  7. db: "admin" 

超级用户的role有两种,userAdmin或者userAdminAnyDatabase(比前一种多加了对所有数据库的访问)。

db是指定数据库的名字,admin是管理数据库。

2. 用新创建的用户登录

 

 
  1. mongo --host xxx -u adminUserName -p userPassword --authenticationDatabase admin 

3. 查看当前用户的权限

 

 
  1. db.runCommand( 
  2. usersInfo:"userName"
  3. showPrivileges:true 

4. 创建一般用户,也是用createUser

 

 
  1. use db01 
  2. db.createUser( 
  3. user:"oneUser"
  4. pwd:"12345"
  5. roles:[ 
  6. {role:"read",db:"db01"}, 
  7. {role:"read",db:"db02"}, 
  8. {role:"read",db:"db03"

5. 创建一个不受访问限制的超级用户

 

 
  1. use admin 
  2. db.createUser( 
  3. user:"superuser"
  4. pwd:"pwd"
  5. roles:["root"

6. 修改密码

 

 
  1. use admin 
  2. db.changeUserPassword("username""xxx"

7. 查看用户信息

 

 
  1. db.runCommand({usersInfo:"userName"}) 

8. 修改密码和用户信息

 

 
  1. db.runCommand( 
  2. updateUser:"username"
  3. pwd:"xxx"
  4. customData:{title:"xxx"

注:

1. 和用户管理相关的操作基本都要在admin数据库下运行,要先use admin;

2. 如果在某个单一的数据库下,那只能对当前数据库的权限进行操作;

3. db.addUser是老版本的操作,现在版本也还能继续使用,创建出来的user是带有root role的超级管理员。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表