1 MongoDB是没有默认管理员账号的,所以要先添加管理员账号,在开启权限认证。
2 切换到admin数据库,添加的账号才是管理员的账号。
3 用户只能在用户所在的数据库登录,包括管理员账号。
4 管理员可以管理所有的数据库,但是不能直接管理其它数据库,要先在admin数据库中认证才可以,也是为了 安全性考虑。
MongoDB内置角色官网文档介绍:
https://docs.mongodb.com/manual/security/
大致分为几类:
内建的角色
数据库用户角色:read、readWrite;
数据库管理角色:dbAdmin、dbOwner、userAdmin;
集群管理角色:clusterAdmin、clusterManager、clusterMonitor、hostManager;
备份恢复角色:backup、restore;
所有数据库角色:readAnyDatabase、readWriteAnyDatabase、userAdminAnyDatabase、dbAdminAnyDatabase
超级用户角色:root // 这里还有几个角色间接或直接提供了系统超级用户的访问(dbOwner 、userAdmin、userAdminAnyDatabase)
内部角色:__system
角色说明:
Read :允许用户读取指定数据库
readWrite :允许用户读写指定数据库
dbAdmin :允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile
userAdmin :允许用户向system.users集合写入,可以找指定数据库里创建、删除和管理用户
clusterAdmin :只在admin数据库中可用,赋予用户所有分片和复制集相关函数的管理权限。
readAnyDatabase :只在admin数据库中可用,赋予用户所有数据库的读权限
readWriteAnyDatabase : 只在admin数据库中可用,赋予用户所有数据库的读写权限
userAdminAnyDatabase : 只在admin数据库中可用,赋予用户所有数据库的userAdmin权限
dbAdminAnyDatabase:只在admin数据库中可用,赋予用户所有数据库的dbAdmin权限。
root:只在admin数据库中可用。超级账号,超级权限
1.首次启动容器,启用auth参数,登录数据库
docker run --name mongodb1 -v /data/mongodb1:/data/db -p 27016:27017 -d mongo -auth
此时,执行show dbs,是没有数据库的,admin库是不存在的,需要我们自己创建。
> show dbs
>
(use admin) 使用此命令创建一个admin数据库,权限管理就要使用admin数据库,此命令也是切换数据库的命令
> use admin
switched to db admin
> db.createUser({user: "superadmin", pwd: "superpassword", roles: [{ role: "userAdminAnyDatabase", db: "admin" }]})
Successfully added user: {
"user" : "superadmin",
"roles" : [
{
"role" : "userAdminAnyDatabase",
"db" : "admin"
}
]
}
> db
admin
进行鉴权
> db.auth("superadmin", "superpassword")
1
>
2.使用管理员用户连接admin数据库
[root@VM_0_3_centos ~]# docker exec -it b5de mongo -u "superadmin" -p "superpassword" --authenticationDatabase "admin"
MongoDB shell version v4.0.6
connecting to: mongodb://127.0.0.1:27017/?authSource=admin&gssapiServiceName=mongodb
Implicit session: session { "id" : UUID("a8891d7a-0b8d-41b9-bc38-4e43da6dad11") }
MongoDB server version: 4.0.6
>
> db.auth("superadmin","superpassword")
1
创建两个普通用户,只有读写权限;
> db.createUser({user: "data", pwd: "data", roles: [{ role: "readWrite", db: "data" }]})
Successfully added user: {
"user" : "data",
"roles" : [
{
"role" : "readWrite",
"db" : "data"
}
]
}
> db.createUser({user: "test", pwd: "test", roles: [{ role: "readWrite", db: "test" }]})
Successfully added user: {
"user" : "test",
"roles" : [
{
"role" : "readWrite",
"db" : "test"
}
]
}
3.使用普通用户连接相应的数据库
[root@VM_0_3_centos ~]# docker exec -it b5de mongo -u "test" -p "test" --authenticationDatabase "test"
MongoDB shell version v4.0.6
connecting to: mongodb://127.0.0.1:27017/?authSource=test&gssapiServiceName=mongodb
Implicit session: session { "id" : UUID("90c653e0-80e0-499c-830b-a525de55603d") }
MongoDB server version: 4.0.6
> db
test
> db.auth("test","test")
1
> show collections
> db.student.insert({id:1,name:"test1"})
WriteResult({ "nInserted" : 1 })
> db.student.find()
{ "_id" : ObjectId("5c7f33d69cb585696c593ce5"), "id" : 1, "name" : "test1" }
>
>