MongoDB(72)如何创建用户和角色?

在 MongoDB 中,用户和角色用于管理对数据库的访问和权限控制。通过创建用户和赋予角色,可以细粒度地控制用户对数据库的访问和操作权限。下面是详细的步骤和代码示例,展示如何创建用户和角色。

步骤1:连接到 MongoDB 实例

首先,使用 mongo 客户端连接到 MongoDB 实例:

bash 复制代码
mongo

步骤2:切换到适当的数据库

在 MongoDB 中,用户和角色是针对特定数据库创建的。切换到你希望创建用户的数据库。例如,如果你想在 admin 数据库中创建用户:

javascript 复制代码
use admin

步骤3:创建用户

使用 db.createUser 方法创建用户。以下是创建不同类型用户的示例代码:

3.1. 创建管理员用户

管理员用户具有管理整个 MongoDB 实例的权限。

javascript 复制代码
db.createUser({
  user: "adminUser",
  pwd: "adminPassword",
  roles: [
    { role: "userAdminAnyDatabase", db: "admin" },
    { role: "readWriteAnyDatabase", db: "admin" }
  ]
})

3.2. 创建数据库用户

数据库用户具有对特定数据库的权限。例如,创建一个 testdb 数据库的读写用户:

javascript 复制代码
use testdb

db.createUser({
  user: "dbUser",
  pwd: "dbPassword",
  roles: [
    { role: "readWrite", db: "testdb" }
  ]
})

3.3. 创建只读用户

只读用户只能读取数据,不能进行写操作。例如,创建一个 testdb 数据库的只读用户:

javascript 复制代码
use testdb

db.createUser({
  user: "readonlyUser",
  pwd: "readonlyPassword",
  roles: [
    { role: "read", db: "testdb" }
  ]
})

步骤4:创建自定义角色

MongoDB 允许创建自定义角色,自定义角色可以组合多种权限。以下是一个创建自定义角色的示例:

4.1. 切换到 admin 数据库

javascript 复制代码
use admin

4.2. 创建自定义角色

javascript 复制代码
db.createRole({
  role: "customRole",
  privileges: [
    { resource: { db: "testdb", collection: "" }, actions: [ "find", "update" ] },
    { resource: { db: "testdb", collection: "logs" }, actions: [ "insert", "remove" ] }
  ],
  roles: []
})

这个自定义角色 customRole 具有以下权限:

  • testdb 数据库的所有集合具有 findupdate 操作权限。
  • testdb 数据库的 logs 集合具有 insertremove 操作权限。

步骤5:将角色赋予用户

可以将创建的自定义角色赋予用户。例如,将 customRole 赋予 dbUser

javascript 复制代码
use testdb

db.updateUser("dbUser", {
  roles: [
    { role: "customRole", db: "testdb" }
  ]
})

步骤6:验证用户和角色

使用新创建的用户连接到 MongoDB 实例并验证权限。例如,使用 dbUser 连接到 testdb 数据库:

bash 复制代码
mongo -u "dbUser" -p "dbPassword" --authenticationDatabase "testdb"

尝试进行各种操作以验证权限:

javascript 复制代码
use testdb

// 验证读写权限
db.collection_name.insert({ "key": "value" })        // 应该成功
db.collection_name.find()                            // 应该成功
db.collection_name.update({ "key": "value" }, { $set: { "key": "newValue" } }) // 应该成功

// 验证自定义角色权限
db.logs.insert({ "log": "entry" })                  // 应该成功
db.logs.remove({ "log": "entry" })                  // 应该成功
db.collection_name.drop()                           // 应该失败,除非用户有该权限

完整示例脚本

以下是一个完整的脚本,展示了如何创建用户和自定义角色:

bash 复制代码
#!/bin/bash

MONGO_HOST="localhost"
MONGO_PORT="27017"

# MongoDB 管理员用户
ADMIN_USER="admin"
ADMIN_PASS="adminPassword"

# 新用户和角色的配置
DB_NAME="testdb"
NEW_USER="dbUser"
NEW_PASS="dbPassword"
CUSTOM_ROLE="customRole"

# 创建管理员用户
mongo --host $MONGO_HOST --port $MONGO_PORT admin <<EOF
db.createUser({
  user: "$ADMIN_USER",
  pwd: "$ADMIN_PASS",
  roles: [
    { role: "userAdminAnyDatabase", db: "admin" },
    { role: "readWriteAnyDatabase", db: "admin" }
  ]
})
EOF

# 创建自定义角色
mongo --host $MONGO_HOST --port $MONGO_PORT -u "$ADMIN_USER" -p "$ADMIN_PASS" --authenticationDatabase "admin" admin <<EOF
db.createRole({
  role: "$CUSTOM_ROLE",
  privileges: [
    { resource: { db: "$DB_NAME", collection: "" }, actions: [ "find", "update" ] },
    { resource: { db: "$DB_NAME", collection: "logs" }, actions: [ "insert", "remove" ] }
  ],
  roles: []
})
EOF

# 创建新用户并赋予自定义角色
mongo --host $MONGO_HOST --port $MONGO_PORT -u "$ADMIN_USER" -p "$ADMIN_PASS" --authenticationDatabase "admin" $DB_NAME <<EOF
db.createUser({
  user: "$NEW_USER",
  pwd: "$NEW_PASS",
  roles: [
    { role: "$CUSTOM_ROLE", db: "$DB_NAME" }
  ]
})
EOF

总结

通过上述步骤和代码示例,可以在 MongoDB 中创建用户、赋予角色和创建自定义角色。确保使用强密码,并根据具体需求细粒度地管理用户权限,以提升数据库的安全性和管理效率。

相关推荐
GetcharZp6 小时前
拒绝低效!这款神器,让你的终端效率起飞 | 深度解析 fzf 终极指南
后端
自珍JAVA7 小时前
高效处理Long列表与集合运算:基于RoaringBitmap的工具类解析与应用场景
后端
小码哥_常7 小时前
Spring Boot项目上线秘籍:日志、监控、异常处理全攻略
后端
GreenTea7 小时前
AI 时代,工程师的不可替代性在哪里
前端·人工智能·后端
朦胧之8 小时前
AI 编程开发思维
前端·后端·ai编程
希望永不加班9 小时前
Spring AOP 代理模式:CGLIB 与 JDK 动态代理区别
java·开发语言·后端·spring·代理模式
浮游本尊10 小时前
一次合同同步背后的多阶段流水线:从外部主数据到本地歧义消解
后端
lv__pf10 小时前
springboot原理
java·spring boot·后端
段小二11 小时前
服务一重启全丢了——Spring AI Alibaba Agent 三层持久化完整方案
java·后端