问题:使用 mongodb 4.x 节点驱动程序连接到 documentDB,端口转发不起作用

我已经在本地设置了一个端口转发到在 mongodb 驱动程序版本 3.x 上成功运行的 documentDB。当我将 mongodb 包更新到 4.x 时,我收到一个超时错误,原因是 ReplicaSetNoPrimary。

代码非常简单:

const MongoClient = require('mongodb').MongoClient;


const client = new MongoClient('mongodb://xxxx:xxxx@localhost:27017');


client.connect(function(err) {
  if (err) {
    console.log(err);
    return;
  }
  
  const db = client.db('testdb');

  console.log("Connected successfully to server");

  client.close();
});

有没有人能够使用 4.x 驱动程序的端口转发在本地连接到 documentDB?我是否缺少某种配置选项? (请记住,我已禁用所有 tls 和一切以使其更易于连接,并且如前所述,在使用 mongodb 3.x 包时成功连接)

解答

连接到副本集时,驱动程序:

  1. 使用连接字符串中的主机作为种子进行初始连接。

  2. 在该初始连接上运行isMasterhello命令以获取 host:port 副本集成员的完整列表及其当前状态

  3. 删除初始连接

  4. 连接到第 2 步中发现的每个成员

5.在操作期间,自动监控所有成员,即使不同节点成为主节点,也将操作发送到主节点

在您的场景中,即使您连接到localhost,初始连接也会返回副本集配置中包含的主机:端口对。

这刚刚成为问题的原因是 MongoDB 驱动程序规范更改为默认使用统一拓扑。

统一拓扑允许驱动程序自动检测它是否连接到独立实例、副本集或分片集群,这简化了连接过程并减少了更改数据库部署方式时所需的管理开销。

由于您的连接失败,我假设副本集配置中列出的主机名:端口对不可解析或无法从测试主机访问。

要解决这种情况:

  • 使这台机器可以通过 DNS 或 hosts 文件解析主机名,并允许通过任何防火墙连接到这些端口

  • 使用directConnection=true连接选项禁用拓扑发现

Logo

MongoDB社区为您提供最前沿的新闻资讯和知识内容

更多推荐