码迷,mamicode.com
首页 > 数据库 > 详细

mongodb07---用户权限

时间:2017-12-30 23:34:59      阅读:165      评论:0      收藏:0      [点我收藏+]

标签:简化   --   sre   超级用户   clu   用户密码   超级   用户   body   

用户管理:


注意: 添加用户后,我们再次退出并登陆,发现依然可以直接读数据库?
原因: mongodb服务器启动时, 默认不是需要认证的.
要让用户生效, 需要启动服务器时,就指定 --auth 选项.
这样, 操作时,就需要认证了.


use admin   //在mongodb中,有一个admin数据库, 牵涉到服务器配置层面的操作,需要先切换到admin数据.即 use admin , 相当于进入超级用户管理模式。在mysql中建立用户名和密码是以库表主机为单位,mongo中简单一些是以库为单位的,每个数据库有自己的管理员。
//要想设置用户,先切到admin下,建立一个管理员,以后这个管理员就是超级管理员。
//需要先在admin数据库下建立管理员---这个管理员登陆后,相当于超级管理员.


1: 添加用户
命令:db.addUser();
简单参数: db.addUser(用户名,密码,是否只读)

1: 添加用户
> use admin
> db.addUser(‘sa’,’sa’,false);

2: 认证
> use test
> db.auth(用户名,密码);

3: 修改用户密码
> use test
> db.changeUserPassword(用户名, 新密码);

3:删除用户
> use test
> db.removeUser(用户名);

注: 如果需要给用户添加更多的权限,可以用json结构来传递用户参数
例:
> use test
>db.addUser({user:guan,pwd:111111,roles:[‘readWrite,dbAdmin‘]});


db.addUser();
{user:xx,pwd:yy,roles:[‘readWrite‘]}
一般用户可以简化为:  db.addUser(user,pwd,isReadOnly);

roles有:
read,readWrite,dbAdmin,userAdmin,clusterAdmin,readAnyDatabase,readWriteAnyDatabase,userAdminAnyDatabase,dbAdminAnyDatabase

db.removeUser(userName);

db.changeUserPassword(userName,newPwd);
db.auth(user,pwd);

 

mongodb07---用户权限

标签:简化   --   sre   超级用户   clu   用户密码   超级   用户   body   

原文地址:https://www.cnblogs.com/yaowen/p/8151304.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!