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

本文共 1349 字,大约阅读时间需要 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 = 3
db.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

你可能感兴趣的文章
nodejs系列之Koa2
查看>>
Nodejs连接mysql
查看>>
nodejs连接mysql
查看>>
NodeJs连接Oracle数据库
查看>>
nodejs配置express服务器,运行自动打开浏览器
查看>>
NodeMCU教程 http请求获取Json中文乱码解决方案
查看>>
Nodemon 深入解析与使用
查看>>
NodeSession:高效且灵活的Node.js会话管理工具
查看>>
node~ http缓存
查看>>
node不是内部命令时配置node环境变量
查看>>
node中fs模块之文件操作
查看>>
Node中同步与异步的方式读取文件
查看>>
node中的get请求和post请求的不同操作【node学习第五篇】
查看>>
Node中的Http模块和Url模块的使用
查看>>
Node中自启动工具supervisor的使用
查看>>
Node入门之创建第一个HelloNode
查看>>
node全局对象 文件系统
查看>>
Node出错导致运行崩溃的解决方案
查看>>
Node响应中文时解决乱码问题
查看>>
node基础(二)_模块以及处理乱码问题
查看>>