Mongodb数据库的权限管理(创建用户、超级管理员)

Mongodb的权限管理

1.为什么要进行权限管理的设置
刚安装完毕的mongodb默认不使用权限认证方式启动,与MySQL不同,mongodb在安装的时候并没有设置权限,然而公网运行系统需要设置权限以保证数据安全,所以我们要学习mongodb的权限管理

2.mongodb的权限管理方案
MongoDB是没有默认管理员账号,所以要先添加管理员账号,并且mongodb服务器需要在运行的时候开启验证模式

  • 用户只能在用户所在数据库登录(创建用户的数据库),包括管理员账号。
  • 管理员可以管理所有数据库,但是不能直接管理其他数据库,要先认证后才可以。

3.mongodb超级管理员账号的创建

3.1 创建超级用户
进入mongo shell

sudo mongod

使用admin数据库(超级管理员账号必须创建在该数据库上)

use admin

创建超级用户

db.createUser({"user":"root_name","pwd":"password","roles":["root"]})

创建成功会显示如下信息
Successfully added user: { “user” : “root_name”, “roles” : [ “root” ] }
退出mongo shell

exit

3.2 以权限认证的方式启动mongodb数据库

sudo mongod --auth

启动之后在启动信息中会有如下信息,说明mongodb以权限认证的方式启动成功
[initandlisten] options: { security: { authorization: “enabled” } }

3.3 登录验证
此时再使用数据库各命令的时候会报权限错误,需要认证才能执行相应操作、

use admin
db.auth('root_name','password')
  • root_name用户是创建在admin数据库上的所以必须来到admin数据库上进行认证
  • 认证成功会返回1,失败返回0

4.创建普通用户
4.1 在使用的数据库上创建普通用户
1.选择需要创建用户的数据库

use test1

创建用户:
创建普通用户user1,该用户在test1上的权限是只读

db.createUser("user":"user1", "pwd":"pwd1", roles:["read"])

创建普通用户user1,该用户在test1上的权限是读写

db.createUser("user":"user1", "pwd":"pwd1", roles:["readWrite"])

4.2 在admin用户数据库上创建普通用户

use admin
db.createUser({"user":"python1", "pwd":"python1", roles:[{"role":"read","db":"dbname1"},{"role":"readWrite","db":"dbname2"}
]})

在admin上创建python1用户,python1用户的权限有两个,一个再dbname1上的只读,另一个是在dbname2上的读写

5.查看创建的用户

show users
{
    "_id" : "admin.python",
    "user" : "python",
    "db" : "admin",
    "roles" : [
        {
            "role" : "root",
            "db" : "admin"
        }
    ]
}

6.删除用户
6.1 进入账号数据所在的数据库

use db_name

6.2 删除用户

db.dropUser('python')
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要创建MongoDB超级管理员,您可以按照以下步骤进行操作: 1. 首先,使用mongo命令进入MongoDB的shell环境。命令如下: ``` mongo ``` 2. 进入admin数据库。命令如下: ``` use admin ``` 3. 创建超级管理员用户。您可以使用以下命令创建一个用户名为"root",密码为"123456"的超级管理员用户,并分配"root"角色: ``` db.createUser({user:"root",pwd:"123456",roles:\[{role:"root",db:"admin"}\]}) ``` 4. 进行身份验证,即使用刚创建的超级管理员用户登录。命令如下: ``` db.auth("root","123456") ``` 5. 确认登录成功后,您可以执行其他操作,如查看数据库、查看当前所在数据库、获取当前数据库的所有用户等。例如,您可以使用以下命令查看当前数据库的所有用户: ``` db.getUsers() ``` 请注意,上述命令中的用户名和密码仅用于演示,实际使用时应设置更强的密码来确保安全性。另外,为了使角色有效,您还需要在启动MongoDB服务时加入--auth参数进行身份验证。 参考资料: \[1\] 引用内容来源:mongodb安装成功之后是没有超级管理员的,需要我们自行创建。默认情况下,mongodb默认有三个集合,分别为admin,config,local,我将会在admin这个集合上创建超级管理员,也就是添加用户与分配角色。 \[2\] 引用内容来源:开发过管理后台的同学们多多少少都接触过权限管理,所谓的权限管理,一般指根据系统设置的安全规则或者安全策略,用户可以访问而且只能访问自己被授权的资源。常用的还是基于角色的权限模型(RBAC),mongodb用户角色管理也是基于RBAC模型。知道了这些我们可以带着问题去做实验,学习mongodb权限管理。关于mongodb权限管理的更多参考可以查看官方的文档手册,mongodb用户管理方法。 \[3\] 引用内容来源:想让角色有效mongodb服务必须加入auth验证 根据自己的路径设置 binpath sc create MongoDB_Auth binpath=“D:\MongoDB\bin\mongod.exe --dbpath D:\MongoDB\data\db --logpath D:\MongoDB\log\mongo.log --logappend --auth --service” 开启验证之后 可以用账号密码登录 mongo admin -u admin -p 123。 #### 引用[.reference_title] - *1* *2* [mongodb权限管理篇](https://blog.csdn.net/Y00010010/article/details/123945756)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [mongodb创建管理用户](https://blog.csdn.net/qq_40009711/article/details/88700391)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值