博客
关于我
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工作笔记0020---Selectionkey在NIO体系
查看>>
Vue踩坑笔记 - 关于vue静态资源引入的问题
查看>>
Netty工作笔记0024---SelectionKey API
查看>>
Netty工作笔记0025---SocketChannel API
查看>>
Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
查看>>
Netty工作笔记0028---NIO 网络编程应用--群聊系统3--客户端编写1
查看>>
Netty工作笔记0034---Netty架构设计--线程模型
查看>>
Netty工作笔记0050---Netty核心模块1
查看>>
Netty工作笔记0057---Netty群聊系统服务端
查看>>
Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
查看>>
Netty工作笔记0063---WebSocket长连接开发2
查看>>
Netty工作笔记0070---Protobuf使用案例Codec使用
查看>>
Netty工作笔记0072---Protobuf内容小结
查看>>
Netty工作笔记0074---handler链调用机制实例1
查看>>
Netty工作笔记0077---handler链调用机制实例4
查看>>
Netty工作笔记0081---编解码器和处理器链梳理
查看>>
Netty工作笔记0083---通过自定义协议解决粘包拆包问题1
查看>>
Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
查看>>
Netty工作笔记0085---TCP粘包拆包内容梳理
查看>>
Netty常用组件一
查看>>