博客
关于我
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

你可能感兴趣的文章
NFS
查看>>
NFS Server及Client配置与挂载详解
查看>>
NFS 服务配置篇
查看>>
NFS共享文件系统搭建
查看>>
nfs复习
查看>>
NFS安装配置
查看>>
NFS服务器配置-服务启动与停止
查看>>
NFS的安装以及windows/linux挂载linux网络文件系统NFS
查看>>
NFS的常用挂载参数
查看>>
NFS网络文件系统
查看>>
NFS远程目录挂载
查看>>
nft文件传输_利用remoting实现文件传输-.NET教程,远程及网络应用
查看>>
NFV商用可行新华三vBRAS方案实践验证
查看>>
ng build --aot --prod生成文件报错
查看>>
ng 指令的自定义、使用
查看>>
ng6.1 新特性:滚回到之前的位置
查看>>
nghttp3使用指南
查看>>
Nginx
查看>>
nginx + etcd 动态负载均衡实践(一)—— 组件介绍
查看>>
nginx + etcd 动态负载均衡实践(三)—— 基于nginx-upsync-module实现
查看>>