使用 Docker 部署 Mongodb 集群后项目中的连接问题

本贴最后更新于 1291 天前,其中的信息可能已经事过景迁

问题

CentOS 7 + docker + mongodb 4.4.4 部署了一个 mongodb 集群,然后在项目(Java-springboot)中去连接 mongodb 进行数据的读写,出现如下提示:

2021-05-12 13:42:33.003  INFO 17864 --- [io-8084-exec-10] org.mongodb.driver.cluster               : Cluster created with settings {hosts=[121.*.*.56:27017], mode=MULTIPLE, requiredClusterType=UNKNOWN, serverSelectionTimeout='30000 ms', maxWaitQueueSize=1500000}
2021-05-12 13:42:33.003  INFO 17864 --- [io-8084-exec-10] org.mongodb.driver.cluster               : Adding discovered server 121.*.*.56:27017 to client view of cluster
2021-05-12 13:42:33.006  INFO 17864 --- [io-8084-exec-10] org.mongodb.driver.cluster               : No server chosen by WritableServerSelector from cluster description ClusterDescription{type=UNKNOWN, connectionMode=MULTIPLE, serverDescriptions=[ServerDescription{address=121.36.16.56:27017, type=UNKNOWN, state=CONNECTING}]}. Waiting for 30000 ms before timing out
2021-05-12 13:42:33.108  INFO 17864 --- [.*.*.56:27017] org.mongodb.driver.connection            : Opened connection [connectionId{localValue:985, serverValue:377}] to 121.*.*.56:27017
2021-05-12 13:42:33.133  INFO 17864 --- [.*.*.56:27017] org.mongodb.driver.cluster               : Monitor thread successfully connected to server with description ServerDescription{address=121.*.*.56:27017, type=REPLICA_SET_PRIMARY, state=CONNECTED, ok=true, version=ServerVersion{versionList=[4, 4, 4]}, minWireVersion=0, maxWireVersion=9, maxDocumentSize=16777216, roundTripTimeNanos=25262872, setName='mongoreplset', canonicalAddress=172.17.0.4:27017, hosts=[172.17.0.4:27017, 121.*.*.103:27017, 172.17.0.6:27017], passives=[], arbiters=[], primary='172.17.0.4:27017', tagSet=TagSet{[]}, electionId=7fffffff0000000000000024, setVersion=2, lastWriteDate=Wed May 12 13:42:42 CST 2021, lastUpdateTimeNanos=533944664886564}
2021-05-12 13:42:33.134  INFO 17864 --- [.*.*.56:27017] org.mongodb.driver.cluster               : Discovered cluster type of REPLICA_SET
2021-05-12 13:42:33.134  INFO 17864 --- [.*.*.56:27017] org.mongodb.driver.cluster               : Adding discovered server 172.17.0.4:27017 to client view of cluster
2021-05-12 13:42:33.135  INFO 17864 --- [.*.*.56:27017] org.mongodb.driver.cluster               : Adding discovered server 121.*.*.103:27017 to client view of cluster
2021-05-12 13:42:33.136  INFO 17864 --- [.*.*.56:27017] org.mongodb.driver.cluster               : Adding discovered server 172.17.0.6:27017 to client view of cluster
2021-05-12 13:42:33.137  INFO 17864 --- [.*.*.56:27017] org.mongodb.driver.cluster               : Server 121.*.*.56:27017 is no longer a member of the replica set.  Removing from client view of cluster.
2021-05-12 13:42:33.137  INFO 17864 --- [.*.*.56:27017] org.mongodb.driver.cluster               : Canonical address 172.17.0.4:27017 does not match server address.  Removing 121.36.16.56:27017 from client view of cluster
2021-05-12 13:42:34.212  INFO 17864 --- [*.*.103:27017] org.mongodb.driver.cluster               : Exception in monitor thread while connecting to server 121.*.*.103:27017

进入 mongodb 容器中,查看当前 rs.conf()

mongoreplset:PRIMARY> rs.conf()
{
        "_id" : "mongoreplset",
        "version" : 2,
        "term" : 36,
        "protocolVersion" : NumberLong(1),
        "writeConcernMajorityJournalDefault" : true,
        "members" : [
                {
                        "_id" : 0,
                        "host" : "172.17.0.4:27017",
                        "arbiterOnly" : false,
                        "buildIndexes" : true,
                        "hidden" : false,
                        "priority" : 1,
                        "tags" : {
                      
                        },
                        "slaveDelay" : NumberLong(0),
                        "votes" : 1
                },
                {
                        "_id" : 1,
                        "host" : "172.17.0.6:27017",
                        "arbiterOnly" : false,
                        "buildIndexes" : true,
                        "hidden" : false,
                        "priority" : 1,
                        "tags" : {
                      
                        },
                        "slaveDelay" : NumberLong(0),
                        "votes" : 1
                },
		...

可以看到现在的复制集中使用的是非外网 IP 配置的,此时,在项目中连接时就会出现上面的连接不通问题。

后来重新部署,然后将其中的 host 换为服务器 IP:port 后,就可以正常连接读写数据了。

问题:

是否只能如此配置外网 ip?

如果配置宿主机内的 ip ,应该如何配置才能不报错,是不是需要配置 宿主机上的 hosts 映射到内网 ip ?

  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    90 引用 • 59 回帖 • 1 关注
  • Docker

    Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的操作系统上。容器完全使用沙箱机制,几乎没有性能开销,可以很容易地在机器和数据中心中运行。

    491 引用 • 917 回帖 • 4 关注
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    8128 引用 • 37050 回帖 • 160 关注

相关帖子

被采纳的回答
  • MingGH 1 1 赞同

    虽然没有配置过 mongodb 集群,但是碰到过类似问题给你参考参考。
    我搭建的是 redis 集群,3 主 3 从 6 个 container 通过 docker 的 bridge 中进行通信,也就是这样

    docker network create -d bridge  --subnet=192.168.1.0/24 localBr
    

    然后问题来了,当我用项目去连接的时候,返回给我的是 docker 中的 bridge 指定的 ip,因为我创建 redis container 的命令大概是这样的,带了指定的 bridge 以及 ip

    docker run --network localBr --ip 192.168.1.102 --name redis -p 6379:6379 -d --restart=always redis:latest redis-server --appendonly yes --requirepass "123456"
    

    所以除非我的项目也能连接到我创建的 bridge,不然肯定连接不上集群
    所以把 docker 创建 redis 的命令改了一下,不走 bridge,而是 host 模式 --net=host
    然后确实可以了,但是这样每个 redis 容器都要占用一个宿主机的端口

    如果有更好的办法提醒我一下

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
PeterChu
人生是场修行,求知是种信仰 ! 北京

推荐标签 标签

  • Bootstrap

    Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

    18 引用 • 33 回帖 • 659 关注
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖
  • Solidity

    Solidity 是一种智能合约高级语言,运行在 [以太坊] 虚拟机(EVM)之上。它的语法接近于 JavaScript,是一种面向对象的语言。

    3 引用 • 18 回帖 • 399 关注
  • SQLServer

    SQL Server 是由 [微软] 开发和推广的关系数据库管理系统(DBMS),它最初是由 微软、Sybase 和 Ashton-Tate 三家公司共同开发的,并于 1988 年推出了第一个 OS/2 版本。

    21 引用 • 31 回帖 • 1 关注
  • React

    React 是 Facebook 开源的一个用于构建 UI 的 JavaScript 库。

    192 引用 • 291 回帖 • 385 关注
  • ngrok

    ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。

    7 引用 • 63 回帖 • 624 关注
  • ZeroNet

    ZeroNet 是一个基于比特币加密技术和 BT 网络技术的去中心化的、开放开源的网络和交流系统。

    1 引用 • 21 回帖 • 638 关注
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖
  • 游戏

    沉迷游戏伤身,强撸灰飞烟灭。

    176 引用 • 815 回帖
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    334 引用 • 323 回帖 • 2 关注
  • Sphinx

    Sphinx 是一个基于 SQL 的全文检索引擎,可以结合 MySQL、PostgreSQL 做全文搜索,它可以提供比数据库本身更专业的搜索功能,使得应用程序更容易实现专业化的全文检索。

    1 引用 • 211 关注
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    133 引用 • 189 回帖
  • Telegram

    Telegram 是一个非盈利性、基于云端的即时消息服务。它提供了支持各大操作系统平台的开源的客户端,也提供了很多强大的 APIs 给开发者创建自己的客户端和机器人。

    5 引用 • 35 回帖 • 2 关注
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    166 引用 • 595 回帖 • 1 关注
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 483 关注
  • 安全

    安全永远都不是一个小问题。

    199 引用 • 816 回帖
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    58 引用 • 22 回帖
  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    543 引用 • 672 回帖
  • 反馈

    Communication channel for makers and users.

    123 引用 • 911 回帖 • 245 关注
  • BookxNote

    BookxNote 是一款全新的电子书学习工具,助力您的学习与思考,让您的大脑更高效的记忆。

    笔记整理交给我,一心只读圣贤书。

    1 引用 • 1 回帖
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    21 引用 • 245 回帖 • 240 关注
  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 27 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    77 引用 • 430 回帖
  • 强迫症

    强迫症(OCD)属于焦虑障碍的一种类型,是一组以强迫思维和强迫行为为主要临床表现的神经精神疾病,其特点为有意识的强迫和反强迫并存,一些毫无意义、甚至违背自己意愿的想法或冲动反反复复侵入患者的日常生活。

    15 引用 • 161 回帖
  • 持续集成

    持续集成(Continuous Integration)是一种软件开发实践,即团队开发成员经常集成他们的工作,通过每个成员每天至少集成一次,也就意味着每天可能会发生多次集成。每次集成都通过自动化的构建(包括编译,发布,自动化测试)来验证,从而尽早地发现集成错误。

    15 引用 • 7 回帖 • 1 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    107 引用 • 153 回帖 • 3 关注
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    125 引用 • 588 回帖