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.com
、node2.example.com
和 node3.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 记录设置方法