连接 mongodb集群的集中方式

mongodb 连接到复制集

mongodb://node1,node2,node3.../database?[options]

mongodb 连接到分片集

mongodb://mongos1,mongos2,mongos3.../database?[options]

使用 mongo+srv

通过域名解析得到所有的 mongos 或 节点的地址, 而不是把这些写在连接字符串中.

mongodb+srv://server.example.com

mongo+srv:// 是 MongoDB 连接字符串中的一种格式,用于指示 MongoDB 驱动程序使用 DNS SRV 记录来查找 MongoDB 集群的地址信息。通过使用 mongo+srv:// 连接字符串,您可以只提供集群的域名而不是具体的主机名和端口号,MongoDB 驱动程序将自动查找 DNS 中的 SRV 记录来获取集群的连接信息。

要配置域名以供使用 mongo+srv:// 连接字符串,您需要在 DNS 服务器中设置相应的 SRV 记录。以下是一个示例说明如何设置 SRV 记录:

假设您有一个 MongoDB 集群,域名为 example.com,并且集群中有三个节点:node1.example.com、node2.example.com 和 node3.example.com。您可以在 DNS 服务器中为 example.com 添加一个 SRV 记录,指向您的 MongoDB 集群。

示例 SRV 记录的格式如下:

_mongodb._tcp.example.com. IN SRV <priority> <weight> <port> <target>
  • _mongodb._tcp.example.com.:SRV 记录的名称,包括服务类型和域名。
  • IN: 记录的类别,表示 Internet 类型。
  • SRV: 记录的类型,表示服务定位记录。
  • <priority>: 优先级,通常设置为 0。
  • <weight>: 权重,通常设置为 0。
  • <port>: MongoDB 服务器的端口号,通常设置为 27017。
  • <target>: 目标主机名,即 MongoDB 服务器的主机名。

假设您将三个节点分别设置为优先级为 0、权重为 0、端口为 27017,并且主机名分别为 node1.example.comnode2.example.comnode3.example.com,则您可以在 DNS 中添加如下的 SRV 记录:

_mongodb._tcp.example.com. IN SRV 0 0 27017 node1.example.com.
_mongodb._tcp.example.com. IN SRV 0 0 27017 node2.example.com.
_mongodb._tcp.example.com. IN SRV 0 0 27017 node3.example.com.

添加完 SRV 记录后,就可以在 MongoDB 连接字符串中使用 mongo+srv://example.com 来连接您的 MongoDB 集群了。MongoDB 驱动程序会自动查找 DNS 中的 SRV 记录,并使用其中的地址信息来连接集群。

阿里云配置 SRV 记录

记录类型选择 SRV

记录值配置类似:

0 0 27017 node1.example.com

阿里云官方文档 - 域名解析 SRV 记录设置方法

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值