【问题标题】:Docker MongoNetworkError: connection timed out when build Node JS App by dockerDocker MongoNetworkError:通过docker构建Node JS App时连接超时
【发布时间】:2019-07-10 13:56:07
【问题描述】:

无法连接到 Mongodb。由 Docker 安装的

let dbRoute = "mongodb://mongo:27017/kgp_news"

const option = {
    socketTimeoutMS: 30000,
    keepAlive: true,
    reconnectTries: 30000,
    useNewUrlParser: true 
};

mongoose.connect(dbRoute, option)

我通过 docker 安装 mongo。它运行端口 27017。

当我通过脚本“node index.js”运行项目时。它正在工作。

但是当我通过编写 Dockerfile 构建应用程序时。无法连接到 Mongo。 MongoNetworkError: connection timed out

    at Pool.<anonymous> (/api_kgp/docker_build/node_modules/mongodb-core/lib/topologies/server.js:431:11)
    at Pool.emit (events.js:198:13)
    at connect (/api_kgp/docker_build/node_modules/mongodb-core/lib/connection/pool.js:557:14)
    at makeConnection (/api_kgp/docker_build/node_modules/mongodb-core/lib/connection/connect.js:39:11)
    at callback (/api_kgp/docker_build/node_modules/mongodb-core/lib/connection/connect.js:261:5)
    at Socket.err (/api_kgp/docker_build/node_modules/mongodb-core/lib/connection/connect.js:286:7)
    at Object.onceWrapper (events.js:286:20)
    at Socket.emit (events.js:198:13)
    at Socket._onTimeout (net.js:442:8)
    at ontimeout (timers.js:436:11)
    at tryOnTimeout (timers.js:300:5)
    at listOnTimeout (timers.js:263:5)
    at Timer.processTimers (timers.js:223:10)
(node:20) UnhandledPromiseRejectionWarning: Unhandled promise rejection. This error originated either by throwing inside of an async function without a catch block, or by rejecting a promise which was not handled with .catch(). (rejection id: 1)
(node:20) [DEP0018] DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.

【问题讨论】:

  • mongo 在 node.js 服务器中,你可以ping mongo 吗?和 telnet 到端口 27017
  • @ThanhNguyenVan 我尝试了这个结果:PING mongo.com (54.173.82.137) 56(84) 字节的数据。它似乎工作。

标签: node.js mongodb docker docker-compose dockerfile


【解决方案1】:

mongo 已安装在 container 上,因此请确保:

  1. 在运行构建container时暴露27017端口,

    docker run -p 27017:27017 ....

  2. node代码中,使用mongo容器连接:容器网络的IP地址网关是172.17.0.1:27017

所以:

let dbRoute = "mongodb://172.17.0.1:27017/kgp_news"

【讨论】:

  • 是的。现在醒了。非常感谢。那么现在当使用这个“172.17.0.1”连接任何docker容器时,对吧?
  • 是的,没错!它与端口不同,属于服务
  • 但是 docker 文档说如果容器在同一个 user defined 桥接网络下,你可以使用 dns 别名。
【解决方案2】:

使用localhost的docker容器正在运行。

let dbRoute = "mongodb://localhost:27017/kgp_news"

const option = {
    socketTimeoutMS: 30000,
    keepAlive: true,
    reconnectTries: 30000,
    useNewUrlParser: true 
};

mongoose.connect(dbRoute, option)

或者,你可以把mongodb condtiner的IP地址。要从 mongodb 容器中获取 IP,请使用 $ docker inspect --format='{{range .NetworkSettings.Networks}}{{.IPAddress}}{{end}}' $INSTANCE_ID

let dbRoute = "mongodb://<MONGODB_IP_ADDRESS>:27017/kgp_news"

const option = {
    socketTimeoutMS: 30000,
    keepAlive: true,
    reconnectTries: 30000,
    useNewUrlParser: true 
};

mongoose.connect(dbRoute, option)

【讨论】:

  • 然后让docker容器的IP运行起来。但是,每次启动 mongodb 容器时,此 ip 都会更改。
猜你喜欢
  • 1970-01-01
  • 2020-05-05
  • 2020-06-15
  • 2015-01-07
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2021-02-03
相关资源
最近更新 更多