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" }

>

>