首页 游戏 软件 资讯 排行榜 专题
首页
系统平台
MongoDB怎么设置用户权限 MongoDB数据库安全访问控制详解

MongoDB怎么设置用户权限 MongoDB数据库安全访问控制详解

热心网友
40
转载
2026-05-06

MongoDB怎么设置用户权限 MongoDB数据库安全访问控制详解

MongoDB怎么设置用户权限 MongoDB数据库安全访问控制详解

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

很多刚接触MongoDB的朋友,在配置权限时都踩过同一个“坑”:默认情况下,MongoDB是不开启权限控制的,但只要你一在mongod.conf里写上security.authorization: enabled(或者旧版的auth=true),所有连接瞬间就会被拒之门外。问题来了——此时你还没来得及创建任何用户,数据库自己就把门锁死了,谁都进不去。所以,正确的操作顺序至关重要:必须先停用认证、创建管理员用户、最后再启用认证。这个顺序一旦搞错,整个流程就会卡死。

怎么创建能管所有库的 root 用户

创建最高权限的root用户,有个必须遵守的规则:这个用户必须建在admin数据库下,并且角色声明里的db字段也必须指定为"admin"。可别想着在test库里创建一个角色为{role: "root", db: "admin"}的用户,那样只会得到一个RoleNotFound错误。

具体步骤其实很清晰:

  • 首先,关闭mongod服务,临时注释掉配置文件里的authorization: enabled这一行,然后重启服务。
  • 连接上数据库后,执行以下命令:
    use admin
    db.createUser({
      user: "root",
      pwd: "your_strong_password",
      roles: [{role: "root", db: "admin"}]
    })
  • 创建成功后,把配置改回来,再次重启mongod服务。
  • 最后,登录时必须显式指定认证数据库:mongo -u root -p --authenticationDatabase admin。这一步很多人会忘。

为什么用 readWriteAnyDatabase 还是查不到某个库

你是不是也遇到过这种情况:给用户赋予了readWriteAnyDatabase角色,以为就能畅通无阻了,结果执行show dbs时却看不到数据库列表?这里有个关键点:readWriteAnyDatabase这个角色,只授予了对所有数据库的“数据读写”权限,它并不包含listDatabases这个操作权限。当你执行show dbs或者db.adminCommand({listDatabases: 1})时,实际上需要的是clusterMonitor角色,或者是readAnyDatabase加上listDatabases的组合权限。

所以,如果你想实现“既能查看所有库名,又能读取所有库数据”,可以这样组合角色:{role: "readAnyDatabase", db: "admin"} 加上 {role: "clusterMonitor", db: "admin"}

另外,给应用账号分配权限时,有个最佳实践:尽量不要使用*AnyDatabase这类全局角色,风险太高。应该把权限限定到具体的业务库,比如{role: "readWrite", db: "myapp"}。还有一个容易混淆的概念:角色必须在admin库创建,但其权限作用范围可以覆盖其他库——db字段只是声明这个角色“属于”哪个库,并不是限制它只能在这个库里生效。

db.createUser()roles 数组容易漏的关键点

一个用户可以拥有多个角色,这在roles数组里体现。但这里有个细节很容易写错:数组里的每个角色对象,其db字段都必须准确指定。例如,你想让一个用户既能管理用户(userAdmin),又能读取orders库,正确的写法应该是:

roles: [
  {role: "userAdmin", db: "admin"},
  {role: "read", db: "orders"}
]

而不是把两个角色合并到一个对象里。这里再补充几个注意事项:

userAdminuserAdminAnyDatabase这两个管理用户的角色,都只能在admin数据库下生效。
– 如果你想创建自定义角色,必须先用db.createRole()创建好,同样需要指定db
– 角色名是大小写敏感的,写readwrite(全小写)是无效的,正确的写法是readWrite

权限生效后连不上?检查这三处

配置完后,遇到Authentication failed或者Unauthorized报错,先别急着怀疑密码错了。很多时候,问题出在“路径”不对。重点检查以下三个地方:

  • 客户端命令:使用mongo shell连接时,有没有加上--authenticationDatabase admin?如果没加,客户端默认会去当前连接的库(比如test)里找用户,当然找不到。
  • GUI工具配置:使用Studio 3T、MongoDB Compass这类图形化工具时,“Authentication Database”这个输入框必须手动填上admin,留空或者填错都会导致连接失败。
  • 连接字符串:在代码或配置文件中使用的连接字符串里,是否包含了authSource=admin参数?一个完整的例子是:mongodb://user:pass@localhost:27017/mydb?authSource=admin

平心而论,MongoDB的权限模型本身并不算复杂。真正的“坑”,往往来自于admin库的中心特殊地位、角色定义与认证库的分离设计,以及命令行、连接字符串、配置文件这三端的参数如果不一致,就极易出错。把这几个关节理顺了,权限配置就能一路畅通。

来源:https://www.php.cn/faq/2422488.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

c++如何获取文件的inode编号_Linux系统调用stat函数用法【技巧】
编程语言
c++如何获取文件的inode编号_Linux系统调用stat函数用法【技巧】

Linux系统编程:使用stat()函数精准获取文件inode编号的完整指南 在Linux系统编程中,获取文件的inode编号是一项基础且关键的操作。标准流程是调用stat()系统调用,填充struct stat数据结构,然后访问其st_ino成员。一个常见误区是字段名称:正确的字段是st_ino,

热心网友
05.06
c++如何读取Linux内核生成的Device Tree二进制流【深度】
编程语言
c++如何读取Linux内核生成的Device Tree二进制流【深度】

C++如何读取Linux内核生成的Device Tree二进制流【深度】 Linux用户态如何解析内核加载的dtb文件 Linux内核在启动过程中会加载并解析dtb(设备树二进制)文件,将其转换为内部数据结构(如struct device_node)。一个关键限制是:**用户态程序无法直接访问内核内

热心网友
05.06
c++如何读取Linux系统的CPU负载信息_/proc/stat解析【实战】
编程语言
c++如何读取Linux系统的CPU负载信息_/proc/stat解析【实战】

实战解析:如何用C++精准读取Linux系统的CPU负载信息 在性能监控和系统调优时,CPU使用率是一个绕不开的核心指标。很多开发者第一反应是去调用系统命令,但直接在程序中解析系统数据源,往往能获得更高效、更灵活的解决方案。今天,我们就来深入聊聊如何从 proc stat这个宝藏文件中,用C++提取

热心网友
05.06
readdir如何实现目录同步
编程语言
readdir如何实现目录同步

用C语言实现目录同步:一个基于readdir的实战示例 在C语言编程实践中,目录同步是文件系统操作中的一项关键任务,广泛应用于数据备份、应用部署和系统管理等场景。readdir函数作为POSIX标准库的重要组成部分,为遍历目录条目提供了高效接口。本文将深入解析如何利用readdir函数构建一个基础目

热心网友
05.05
如何有效利用Node.js日志进行开发
编程语言
如何有效利用Node.js日志进行开发

Node js日志管理最佳实践:提升应用可观测性与排障效率 如何确保您的Node js应用运行稳定、问题排查高效?核心在于构建一套专业的日志管理体系。日志不仅是程序运行的“黑匣子”,更是洞察性能瓶颈、优化代码逻辑、提升运维效率的关键基础设施。以下十项经过验证的实践策略,将帮助您将简单的日志输出转化为

热心网友
05.05

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

蔚来4月销量同比增22.8% ES9将于5月下旬上市
业界动态
蔚来4月销量同比增22.8% ES9将于5月下旬上市

蔚来2026年4月交付数据发布:多品牌齐头并进,累计交付突破110万台 最新数据显示,2026年4月,蔚来公司整体交付新车达到29,356台,实现了22 8%的同比增长。这份成绩单背后,是旗下多品牌矩阵的共同发力。 具体来看,作为基石的蔚来品牌交付了19,024台;而面向主流家庭市场的乐道品牌表现稳

热心网友
05.06
新增“保护正版 人人有责”提示!广电总局集中处理电视剧侵权、盗版等传播
业界动态
新增“保护正版 人人有责”提示!广电总局集中处理电视剧侵权、盗版等传播

集中治理电视剧侵权传播动员会召开,行业版权保护再升级 近日,国家广播电视总局的一场动员会,为视听行业的版权保护工作按下了加速键。这场聚焦于集中治理电视剧侵权传播的会议,传递出的信号明确而有力:打击侵权盗版,维护健康生态,已成行业共识与当务之急。 侵权之害:动摇行业根基 会议一针见血地指出,电视剧乃至

热心网友
05.06
维信诺携全尺寸创新成果闪耀SID DW 2026
业界动态
维信诺携全尺寸创新成果闪耀SID DW 2026

维信诺闪耀SID DW 2026:以“屏台”技术硬核实力,定义下一代显示升级方向 五月初的洛杉矶,再次成为全球显示技术的焦点。当地时间5月5日至7日,国际显示周(SID Display Week)如期而至,这场行业顶级盛会向来是窥探未来显示趋势的绝佳窗口。今年,维信诺携其全尺寸创新成果亮相,可谓阵容

热心网友
05.06
全球手机销量榜最新出炉!苹果彻底杀疯了
业界动态
全球手机销量榜最新出炉!苹果彻底杀疯了

2026年Q1全球手机市场:苹果的“统治力”与安卓的“哑铃困境” 5月6日,市场研究机构Counterpoint发布了2026年第一季度的全球智能手机销量榜单。数据揭示了一个近乎“单方面碾压”的格局:苹果在高端市场展现出绝对的统治力,而安卓阵营则显得有些“无力招架”。 仔细看这份TOP10榜单,iP

热心网友
05.06
丢失7年的手机突然发定位和照片 机主成功找回!魅族客服回应
业界动态
丢失7年的手机突然发定位和照片 机主成功找回!魅族客服回应

快科技5月6日消息:7年前丢的手机发回定位,机主成功找回 今天,一则“7年前丢的手机发回定位,机主找回”的消息,冲上了网络热搜榜。 事件引发广泛讨论后,魅族客服方面向媒体做出了最新回应:只要机主曾在系统中挂失过手机,并且这部手机处于开机联网状态、同时登录了原机主的魅族Flyme账号,手机确实会自动拍

热心网友
05.06