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

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

问题

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 格式,因此可以存储比较复杂的数据类型。

    91 引用 • 59 回帖 • 5 关注
  • Docker

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

    497 引用 • 934 回帖 • 2 关注
  • Q&A

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

    9994 引用 • 45424 回帖 • 74 关注

相关帖子

被采纳的回答
  • 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 容器都要占用一个宿主机的端口

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

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • hjljy 1 评论

    数据库我都是直接装在物理机上的,感觉放在 docker 里面不是很好

    1 回复
    嗯有点道理,现在用 docker 起 mongodb 但是还要做一下数据持久化
    PeterChu
  • 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 容器都要占用一个宿主机的端口

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

    1 回复
  • Gakkiyomi2019 1 评论

    胡说

    😂 来嘛,你说说
    PeterChu
  • PeterChu
    作者

    看到有人使用 docker-compose 搭建,中间用到了 bridge,还不明白做啥用,看了你这个好像有点理解了。

    --net=host 这个是啥来着,我查查去。

    另外,看到下面这个贴中有人的一个回复,好像有点启发,但是好像抓不住到底明白了什么

    如何用 Java(Windows)连接到运行在 Docker 中的 MongoDB 副本集? - 问答 - 云 + 社区 - 腾讯云

    1 回复
  • MingGH 1 赞同 3 评论
    学到了学到了。。👍
    PeterChu
    不过还是用了 3 个端口
    PeterChu
PeterChu
人生是场修行,求知是种信仰 ! 北京

推荐标签 标签

  • IPFS

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

    20 引用 • 245 回帖 • 231 关注
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    35 引用 • 468 回帖 • 760 关注
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    98 引用 • 367 回帖
  • ZeroNet

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

    1 引用 • 21 回帖 • 654 关注
  • TGIF

    Thank God It's Friday! 感谢老天,总算到星期五啦!

    291 引用 • 4495 回帖 • 661 关注
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    85 引用 • 324 回帖
  • API

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

    79 引用 • 431 回帖
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 613 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖 • 1 关注
  • SendCloud

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

    2 引用 • 8 回帖 • 503 关注
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 67 回帖 • 443 关注
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    96 引用 • 155 回帖
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 734 关注
  • Tomcat

    Tomcat 最早是由 Sun Microsystems 开发的一个 Servlet 容器,在 1999 年被捐献给 ASF(Apache Software Foundation),隶属于 Jakarta 项目,现在已经独立为一个顶级项目。Tomcat 主要实现了 JavaEE 中的 Servlet、JSP 规范,同时也提供 HTTP 服务,是市场上非常流行的 Java Web 容器。

    162 引用 • 529 回帖 • 3 关注
  • V2Ray
    1 引用 • 15 回帖 • 2 关注
  • 强迫症

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

    15 引用 • 161 回帖 • 2 关注
  • 持续集成

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

    15 引用 • 7 回帖
  • Electron

    Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。

    15 引用 • 136 回帖 • 1 关注
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖
  • Swagger

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 3 关注
  • SQLServer

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

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

    1999 年 2 月腾讯正式推出“腾讯 QQ”,在线用户由 1999 年的 2 人(马化腾和张志东)到现在已经发展到上亿用户了,在线人数超过一亿,是目前使用最广泛的聊天软件之一。

    45 引用 • 557 回帖
  • 大疆创新

    深圳市大疆创新科技有限公司(DJI-Innovations,简称 DJI),成立于 2006 年,是全球领先的无人飞行器控制系统及无人机解决方案的研发和生产商,客户遍布全球 100 多个国家。通过持续的创新,大疆致力于为无人机工业、行业用户以及专业航拍应用提供性能最强、体验最佳的革命性智能飞控产品和解决方案。

    2 引用 • 14 回帖
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    20 引用 • 37 回帖 • 578 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 2 关注
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    437 引用 • 1238 回帖 • 586 关注
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    118 引用 • 54 回帖 • 3 关注