位置: 编程技术 - 正文

关于Mongodb 认证鉴权你需要知道的一些事(mongo认证失败)

编辑:rootadmin

推荐整理分享关于Mongodb 认证鉴权你需要知道的一些事(mongo认证失败),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:mongodb dba认证,mongodb dba认证,关于mongodb的全面总结,mongodb dba认证,关于mongodb的全面总结,mongodb的认识,mongodb的认识,mongodb考试认证,内容如对您有帮助,希望把文章链接给更多的朋友!

前言

本文主要给大家介绍了Mongodb认证鉴权的一些相关内容,通过设置认证鉴权会对大家的mongodb安全进一步的保障,下面话不多说了,来一起看看详细的介绍吧。

一、Mongodb 的权限管理

认识权限管理,说明主要概念及关系

与大多数数据库一样,Mongodb同样提供了一套权限管理机制。 为了体验Mongodb 的权限管理,我们找一台已经安装好的Mongodb,可以参照这里搭建一个单节点的Mongodb。

直接打开mongo shell:

尝试执行stats命令以查看appdb数据库的状态:

此时的提示正是说明你当前的操作没有获得许可,使用appdb预创建的用户进行鉴权:

可以发现,在通过验明身份之后,stats操作的鉴权获得了许可。

以上例子可能让你对数据库鉴权有了点浅显认识,那么接下来开始说点概念了,大致是叫基于角色的权限控制

[图-角色权限控制]

先解释下图中的几个实体:

Resource,资源 一个资源可以是一个数据库、集合、或者一个集群..往大了说,任何可能被操作的事物都可以被当做资源。 Action,动作 动作是指对资源的一个执行行为,比如读取表、读取数据库,其中读取便是一个动作。 Privilege,权限 权限指的是对某类或某一些资源执行某些动作的允许,与Permission的意义一致。 Role,角色 系统中的角色,通常是代表了一种权力等级的象征,比如论坛中的管理员、版主、游客等等,就是角色; 系统定义中,角色往往代表一组权限的集合。 User,用户 可登录系统的实体,一个用户通常可被赋予多个角色。

噢,关于图的简单解释: 权限定义了对某些资源的某些操作,角色则可以拥有多个权限; 用户User可以被赋予多个角色,从而获得这些角色所拥有的权限以操作某些资源。

对于Mongodb来说,只要开启鉴权,所有的DB访问操作都需要通过权限检查。而大致的操作流程跟下图类似

[图-mongo鉴权]

Mongodb 的用户归属于某个数据库,用户需要在所属的数据库中进行鉴权;一旦通过鉴权,当前的会话(连接)中所有操作将按照用户被赋予的角色权限执行检查。

二、鉴权方式

阐述Mongodb支持的几种鉴权方式 鉴权方式是指Mongodb如何识别接入用户,如何检查权限是否合法的一系列校验机制。

SCRAM-SHA-1 SCRAM-SHA-1 是默认的鉴权机制,定义于 IETF standard, RFC 是一种安全性较高的"挑战-应答"鉴权机制。关于"挑战-应答"可以参考维基百科 MongoDB Challenge and Response (MONGODB-CR) 3.0 以前采用的机制,已经废弃 x. Certificate Authentication. 基于证书的鉴权,采用该方式可建立 SSL/TLS 加密连接 LDAP proxy authentication 基于LDAP 系统的鉴权,仅企业版支持 Kerberos authentication 基于Kerberos 的鉴权,仅企业版支持

SCRAM-SHA-1 是当前推荐使用的鉴权方式,既然如此,有必要上图继续解释:

步骤解读

客户端发起一个SCRAM鉴权请求; 鉴权参数中带上用户名、客户端随机字符串(防止重放攻击); 服务端发出一个挑战响应; 服务侧先检查用户名,通过后生成一个salt因子、迭代数、合并字符串(包含客户端随机串和服务端随机串) 客户端响应一个proof(证明数据)和合并字符串; 响应的 proof数据根据服务所给的随机参数以及客户端密钥生成,是一个客户端签名与密钥异或计算后的结果; 服务端将存储的密钥结合随机参数,使用同样的算法生成签名并校验客户端 proof数据; 若校验通过,服务端采用类似方式发送自己的签名; 客户端校验服务端签名数据。

可以看到,SCRAM鉴权时也类似SSL/TLS 的握手过程,但相比之下简单许多,同时在性能方面也要具备优势; 然后我们看看安全性的部分:

信息窃听,传输过程中全部采用动态签名,保证密码不会被传输; 重放攻击,由于使用了随机数,每次生成的数据都不一样,可避免重复数据攻击; 服务假冒,鉴权过程是双向的,即客户端会校验服务端身份,而服务端密钥也根据密码生成,中间人无法仿造; 存储安全,密码在数据库中均没有明文存储,都通过不可逆的算法加密存储。

另外SCRAM-SHA-1 相比MONGODB-CR的优势还有:

A tunable work factor (iterationCount), 可灵活调整的安全系数 Per-user random salts rather than server-wide salts 每个用户有独立的随机系数 A cryptographically stronger hash function (SHA-1 rather than MD5), 更安全的hash函数 Authentication of the server to the client as well as the client to the server. 支持双向认证

对 SCRAM-SHA-1的实现感兴趣?戳这里

三、内部鉴权

关于Mongodb 认证鉴权你需要知道的一些事(mongo认证失败)

副本集、分片集群内鉴权方式

内部鉴权是指 Mongo集群内部节点之间进行访问的鉴权方式,比如副本集内主备之间的访问、分片集群内Mongos 与Mongod之间的访问。 内部鉴权目前支持两种方式:

KeyFiles 密钥文件方式,采用SCAM-SHA-1 的鉴权机制,文件内包含了一个共享密钥,由集群内所有成员共同持有。 通常,密钥的长度在6-字符内,采用Base编码。如何使用&#; X. 证书 证书鉴权,用于SSL/TLS加密连接通道。 如何使用&#;

四、数据库角色

针对Mongodb数据库中的各种角色进行说明

数据库访问

角色名称 拥有权限 read 允许读取指定数据库的角色 readWrite 允许读写指定数据库的角色

数据库管理

角色名称 拥有权限 dbAdmin 允许用户在指定数据库中执行管理函数,如索引创建、删除,查看统计或访问system.profile userAdmin 允许管理当前数据库的用户,如创建用户、为用户授权 dbOwner 数据库拥有者(最高),集合了dbAdmin/userAdmin/readWrite角色权限

集群管理

角色名称 拥有权限 clusterAdmin 集群最高管理员,集合clusterManager/clusterMonitor/hostManager角色权限 clusterManager 集群管理角色,允许对分片和副本集集群执行管理操作,如addShard,resync等 clusterMonitor 集群监控角色,允许对分片和副本集集群进行监控,如查看serverStatus hostManager 节点管理角色,允许监控和管理节点,比如killOp、shutdown操作

备份恢复

角色名称 拥有权限 backup 备份权限,允许执行mongodump操作 restore 恢复权限,允许执行mongoresotre操作

数据库通用角色

角色名称 拥有权限 readAnyDatabase 允许读取所有数据库 readWriteAnyDatabase 允许读写所有数据库 userAdminAnyDatabase 允许管理所有数据库的用户 dbAdminAnyDatabase 允许管理所有数据库

特殊角色

角色名称 拥有权限 root 超级管理员,拥有所有权限 __system 内部角色,用于集群间节点通讯

基本是这些,有兴趣可看看官方的内置角色 Mongodb 的用户及角色数据一般位于当前实例的 admin数据库,system.users存放了所有数据; 存在例外的情况是分片集群,应用接入mongos节点,鉴权数据则存放于config节点。因此有时候为了方便分片集群管理,会单独为分片内部节点创建独立的管理操作用户;

五、相关操作

简单列举用户权限相关的常用操作

授权启动

默认为非授权启动 也可以通过security.authorization配置指定

创建管理员用户

创建用户

授予权限

删除权限

更多操作

六、常见问题

shell 操作提示错误

原因:当前连接未鉴权或用户没有操作权限 解决:为用户分配适当权限,并执行auth操作,如下:

无法执行 eval 操作

db.eval() 是一个全局操作,可执行任意数据库脚本; 执行该命令需要拥有anyAction或anyResource的权限,通常不建议为数据库用户赋予这样的权限。 该命令存在安全风险,已不建议使用(mongodb 3.0之后已经过期)。

总结

标签: mongo认证失败

本文链接地址:https://www.jiuchutong.com/biancheng/312692.html 转载请保留说明!

上一篇:windows7下使用MongoDB实现仓储设计(windows7基本使用教程)

下一篇:MongoDB TTL索引的实例详解(mongodb 全文索引)

  • 所得税申报表的营业成本包括费用吗
  • 缴纳城镇土地使用税标准
  • 购入原材料计划成本
  • 过路费定额发票还能入账吗
  • 小规模发票单张限额
  • 取得住宿发票的专用发票可以抵扣吗
  • 劳动保险费属于营业外支出吗
  • 买房印花税怎么计算出来
  • 财政部颁布的具体准则
  • 应收账款计提坏账比例
  • 普通发票作废怎么验旧
  • 物业电费加价如何举报
  • 采购入库损耗如何计算
  • 其他应付款能转收入么
  • 长期股权变更
  • 个体户没有三证合一,年检
  • 什么叫记载资金的账簿
  • 保安服务税目
  • 退税记录显示税务审核中
  • 某企业2016年年末经营资产总额为4000万元
  • 增值税多交可以在下一期直接抵吗
  • 法人名下两家公司,客户买货可以用另外一个公司开票吗
  • 经办人需要承担风险盘锦交通运输破坏营商环境
  • 销售商品收到货款20000元存入银行
  • 小规模企业如何收款
  • 不含税进货价
  • 电脑经常蓝屏修复
  • 备用金冲销会计怎么做账
  • 定期存款是否属于受限资金
  • 苹果取消macbook
  • 中秋福利发放现金文案怎么写
  • 工作完工结算是什么意思
  • 增值税一般纳税人资格登记表
  • 海康工业相机彩色改黑白设置
  • PHP:set_file_buffer()的用法_Filesystem函数
  • OSError: [WinError 1455] 页面文件太小,无法完成操作。 Error loading “C:\ProgramData\Anaconda3\lib\site-packages\to
  • php导出表格
  • 特许权使用费20%
  • 外贸企业出口退税流程(详细步骤)
  • thinkphp框架入门
  • php字符串包含某个字符串
  • acpi disabled
  • 电子税务局附加税退税在哪看
  • 销售产品的包装费
  • 税控盘抵扣怎么做账
  • 预收账款包括哪些内容具体明细
  • wordpress主题安装好后怎么设置
  • 富文本word
  • 百旺金赋抄报税指南
  • 存单丢失了,去哪里挂失
  • 房地产企业拆迁补偿费入账要求
  • 汇算清缴 房租
  • 其它应付款是否可以抵扣
  • 转让不动产怎么计算增值税
  • 收到一张发票摘要怎么填
  • 加油费用属于什么科目明细
  • 以前年度应付款少记怎么入账
  • 残疾人就业保障金征收使用管理办法
  • 残疾人就业保障金征收使用管理办法
  • 本年利润年末有余额怎么回事
  • 流动比率和速动比率过高说明什么
  • 预提费用取消了怎么调整
  • 在MySQL中使用GTIDs复制协议和中断协议的教程
  • SQLServer EVENTDATA()函数来获取DDL 触发器信息
  • win7系统安装完后启动不了
  • ubuntu linux
  • u盘安装ubuntu找不到硬盘
  • bboy.exe进程是病毒吗 bboy进程安全吗
  • Win7安装VPN软件后无法上网是什么原因如何解决
  • linux 如何查看端口
  • 金庸笔下十大最受欢迎人物
  • shell脚本介绍
  • python中getattr函数例子
  • 深圳国税服务
  • 党日活动与专业建设结合
  • 广东怎么交农村合作医疗保险
  • 社保ukey怎么使用
  • 增值税检查调整的账务处理
  • 乌市沙区医保局电话是多少
  • 普惠性和非普惠的区别
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设