连接 mongodb集群的集中方式

mongodb 连接到复制集

sh 复制代码
mongodb://node1,node2,node3.../database?[options]

mongodb 连接到分片集

sh 复制代码
mongodb://mongos1,mongos2,mongos3.../database?[options]

使用 mongo+srv

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

sh 复制代码
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.comnode2.example.comnode3.example.com。您可以在 DNS 服务器中为 example.com 添加一个 SRV 记录,指向您的 MongoDB 集群。

示例 SRV 记录的格式如下:

sh 复制代码
_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 记录:

sh 复制代码
_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

记录值配置类似:

sh 复制代码
0 0 27017 node1.example.com

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

相关推荐
cyt涛1 小时前
MyBatis 学习总结
数据库·sql·学习·mysql·mybatis·jdbc·lombok
Rookie也要加油1 小时前
01_SQLite
数据库·sqlite
liuxin334455661 小时前
教育技术革新:SpringBoot在线教育系统开发
数据库·spring boot·后端
看山还是山,看水还是。2 小时前
MySQL 管理
数据库·笔记·mysql·adb
fishmemory7sec2 小时前
Koa2项目实战2(路由管理、项目结构优化)
数据库·mongodb·koa
momo小菜pa2 小时前
【MySQL 09】表的内外连接
数据库·mysql
Jasonakeke3 小时前
【重学 MySQL】四十九、阿里 MySQL 命名规范及 MySQL8 DDL 的原子化
数据库·mysql
程序猿小D3 小时前
第二百六十九节 JPA教程 - JPA查询OrderBy两个属性示例
java·开发语言·数据库·windows·jpa
小宇成长录3 小时前
Mysql:数据库和表增删查改基本语句
数据库·mysql·数据库备份
团儿.4 小时前
解锁MySQL高可用新境界:深入探索MHA架构的无限魅力与实战部署
数据库·mysql·架构·mysql之mha架构