使用Docker构建Node JS应用程序时遇到MongoNetworkError:连接超时

3
无法连接由Docker安装的Mongodb。
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:连接超时

    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 in node.js server, can you ping mongo ? and telnet to port 27017 - Thanh Nguyen Van
@ThanhNguyenVan 我试过了,结果是:PING mongo.com (54.173.82.137) 56(84) 字节的数据。看起来它正常工作。 - Võ Cát Thư
2个回答

6

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

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

    docker run -p 27017:27017 ....

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

因此:

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


是的,现在它正在工作。非常感谢。所以现在连接任何Docker容器时都要使用这个“172.17.0.1”,对吗? - Võ Cát Thư
是的,没错!它与端口不同,属于服务。 - Thanh Nguyen Van
但是Docker文档表示,如果容器在同一个用户定义的桥接网络下,您可以使用DNS别名。 - Hiro

0

使用 localhost 当 Docker 容器正在运行。

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

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

mongoose.connect(dbRoute, option)

或者,您可以将mongodb容器的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都会发生更改。 - prisar

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接