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

你可能感兴趣的文章
non linear processor
查看>>
Non-final field ‘code‘ in enum StateEnum‘
查看>>
none 和 host 网络的适用场景 - 每天5分钟玩转 Docker 容器技术(31)
查看>>
None还可以是函数定义可选参数的一个默认值,设置成默认值时实参在调用该函数时可以不输入与None绑定的元素...
查看>>
NoNodeAvailableException None of the configured nodes are available异常
查看>>
Vue.js 学习总结(16)—— 为什么 :deep、/deep/、>>> 样式能穿透到子组件
查看>>
nopcommerce商城系统--文档整理
查看>>
NOPI读取Excel
查看>>
NoSQL&MongoDB
查看>>
NoSQL介绍
查看>>
NoSQL数据库概述
查看>>
Notadd —— 基于 nest.js 的微服务开发框架
查看>>
NOTE:rfc5766-turn-server
查看>>
Notepad ++ 安装与配置教程(非常详细)从零基础入门到精通,看完这一篇就够了
查看>>
Notepad++在线和离线安装JSON格式化插件
查看>>
notepad++最详情汇总
查看>>
notepad++正则表达式替换字符串详解
查看>>
notepad如何自动对齐_notepad++怎么自动排版
查看>>
Notes on Paul Irish's "Things I learned from the jQuery source" casts
查看>>
Notification 使用详解(很全
查看>>