博客
关于我
MongoDB鉴权降级
阅读量:798 次
发布时间:2023-02-09

本文共 1323 字,大约阅读时间需要 4 分钟。

MongoDB迁移后PHP客户端连接异常问题排查

背景

由于MongoDB迁移导致PHP客户端连接数据库异常,排查发现MongoDB3.0版本的鉴权认证机制采用了SCRAM-SHA-1协议,程序驱动出现异常,需要对鉴权机制进行降级,改用MONGODB-CR进行认证。

鉴权降级操作步骤

在无鉴权状态下登录,执行以下操作:

1. 配置文件注释鉴权

编辑配置文件,注释掉相关鉴权配置:

# security:#   keyFile: /data1/ceshi27020_mongo/etc/keyfile#   authorization: enabled

2. 重启MongoDB

执行sudo systemctl restart mongodb命令重启MongoDB服务。

3. 执行降级命令

在主节点运行以下命令:

db.system.users.find()db.system.version.findOne()var schema = db.system.version.findOne({"_id" : "authSchema"})schema.currentVersion = 3db.system.version.save(schema)

4. 重建用户

删除现有用户并创建新用户:

db.dropUser('test_rw')db.createUser({  "user": "test_rw",  "pwd": "iwoCsl173",  "roles": [{ "role": "readWrite", "db": "lsession" }]})

5. 开启鉴权

编辑配置文件,启用鉴权:

# security:#   keyFile: /data1/ceshi27020_mongo/etc/keyfile#   authorization: enabled

鉴权认证机制说明

  • SCRAM-SHA-1:MongoDB3.0版本默认使用的认证协议。
  • MONGODB-CR:降级后的认证协议。

PHP连接MongoDB示例代码

'admin', 'username' => 'dba', 'password' => 'xxxxxxxx', 'replicaSet' => 'test3', 'readPreference' => MongoClient::RP_SECONDARY_PREFERRED, 'connectTimeoutMS' => 5000);$mongo = new MongoClient($server, $options);$db = $mongo->selectDB('zyq');$coll = $db->selectCollection('test10');$result = $coll->find(array("userid" => 30748));while ($doc = $result->getNext()) { var_dump($doc);}

转载声明

此内容转载自:https://www.cnblogs.com/DBA-3306/p/11097245.html

你可能感兴趣的文章
Netty遇到TCP发送缓冲区满了 写半包操作该如何处理
查看>>
netty(1):NIO 基础之三大组件和ByteBuffer
查看>>
Netty:ChannelPipeline和ChannelHandler为什么会鬼混在一起?
查看>>
Netty:原理架构解析
查看>>
Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
查看>>
Network Sniffer and Connection Analyzer
查看>>
Network 灰鸽宝典【目录】
查看>>
Networkx写入Shape文件
查看>>
NetworkX系列教程(11)-graph和其他数据格式转换
查看>>
Networkx读取军械调查-ITN综合传输网络?/读取GML文件
查看>>
network小学习
查看>>
Netwox网络工具使用详解
查看>>
Net与Flex入门
查看>>
net包之IPConn
查看>>
net发布的dll方法和类显示注释信息(字段说明信息)[图解]
查看>>
Net操作配置文件(Web.config|App.config)通用类
查看>>
NeurIPS(神经信息处理系统大会)-ChatGPT4o作答
查看>>
neuroph轻量级神经网络框架
查看>>
Neutron系列 : Neutron OVS OpenFlow 流表 和 L2 Population(7)
查看>>
NEW DATE()之参数传递
查看>>