默认启动 MongoDB 服务时没有任何参数,可以对数据库任意操 作,而且可以远程访问数据库,所以推荐开发阶段可以不设置任何参数,但对于生产环境还是要仔细考虑一下安全方面的因素,下面就介绍了Mongodb开启用户访问控制的相关资料。 |
前言
Mongodb 数据库默认情况下是没有访问控制的,整个数据库对外是开发的,只要能连上数据库,则可以进行任何操作,这会对数据带来很大的风险。当然,我们可以启用mongodb的访问控制,只让通过认证的用户才能对数据库进行角色范围内的操作。
启用访问控制可以通过在启动 mongodb 时指定 --auth
参数来设置,另外还涉及到创建用户 db.createUser
操作以及一些角色的定义,我们先来看这部分内容。
db.createUser() 用法
db.createUser({ user: "$USERNAME", pwd: "$PASSWROD", roles: [ { role: "$ROLE_NAME", db: "$DBNAME"} ] })
参数说明:
Mongodb 预定义角色
Mongodb 中预定义了一些角色,把这些角色赋予给适当的用户上,用户就只能进行角色范围内的操作。
1、数据库用户角色 (所有数据库都有)
2、数据库管理角色(所有数据库都有)
3、集群管理角色(admin数据库可用)
4、备份和恢复角色(admin数据库可用)
5、所有数据库角色(admin数据库可用)
6、超级角色(admin数据库可用)
7、内部角色
更多预定于角色的信息请参看:https://docs.mongodb.com/manual/core/security-built-in-roles/
启用访问控制的步骤
1, 启动 mongodb 实例,关闭 访问控制
不带 --auth
2, 连接上 mongodb 实例
3,创建用户管理员
在 admin 数据库中添加一个 具有 userAdminAnyDatabase 角色的用户作为用户管理用户。下面的例子中创建了 admin 为用户管理员。
退出连接
4,重启数据库启用访问控制
命令行启动,只需要添加 --auth 参数
5,使用管理用户连接,有两种方法
1,使用命令行 ./mongo -u "$USERNAME" -p "$PASSWROD" --authenticationDatabase "admin" 2,使用 db.auth()
我们使用第二种
1 表示认证成功
6, 为某个数据库创建独立用户
以下为 test 数据库 创建具有读写权限的用户 test
admin 用户由于只有 userAdminAnyDatabase 权限,所以没有 test 数据的读写权限,所以,为了读写 test 数据库,我们需要创建一个用户。先看一下直接用 admin 会报什么错误
我们直接使用 show collections , 则报错:not authorized on test to execute command ,意思是没有权限。
然后我们使用 db.auth(“test”, “test”)
, 再执行命令 则没有报错
试着写入一条数据,也是正常的。
原文:https://www.cnblogs.com/gaomanito/p/11731658.html