Node.js Docker MongoneWorkError:Docker生成节点JS应用程序时连接超时

Node.js Docker MongoneWorkError:Docker生成节点JS应用程序时连接超时,node.js,mongodb,docker,docker-compose,dockerfile,Node.js,Mongodb,Docker,Docker Compose,Dockerfile,无法连接到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。它运行

无法连接到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:连接超时

    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.
在池中。(/api_kgp/docker_build/node_modules/mongodb core/lib/topologies/server.js:431:11)
在Pool.emit(events.js:198:13)
在connect(/api\u kgp/docker\u build/node\u modules/mongodb core/lib/connection/pool.js:557:14)
在makeConnection(/api\u kgp/docker\u build/node\u modules/mongodb core/lib/connection/connect.js:39:11)
回调时(/api\u kgp/docker\u build/node\u modules/mongodb core/lib/connection/connect.js:261:5)
位于Socket.err(/api\u kgp/docker\u build/node\u modules/mongodb core/lib/connection/connect.js:286:7)
在Object.onceWrapper(events.js:286:20)
在Socket.emit(events.js:198:13)
在套接字上超时(net.js:442:8)
在ontimeout(timers.js:436:11)
在tryOnTimeout(timers.js:300:5)
在listOnTimeout(timers.js:263:5)
at Timer.processTimers(timers.js:223:10)
(节点:20)未处理的PromisejectionWarning:未处理的承诺拒绝。此错误源于在没有catch块的异步函数中抛出,或者拒绝未使用.catch()处理的承诺。(拒绝id:1)
(节点:20)[DEP0018]弃用警告:未处理的承诺拒绝已弃用。将来,未处理的承诺拒绝将使用非零退出代码终止Node.js进程。

正在运行docker容器的use
localhost

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

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

mongoose.connect(dbRoute, option)
或者,您可以输入mongodb Conditner的IP地址。要从mongodb conatiner获取IP,请使用
$docker inspect--format='{{range.NetworkSettings.Networks}}}{{.IPAddress}}{{end}}}'$INSTANCE\u ID

let dbRoute=“mongodb://:27017/kgp\u新闻”
常量选项={
socketTimeoutMS:30000,
基帕利夫:是的,
重新连接:30000次,
useNewUrlParser:true
};
mongoose.connect(dbRoute,选项)

mongo
安装在
容器上,因此请确保:

  • 运行以生成容器时暴露
    27017
    端口

    docker run-p 27017:27017….

  • 节点中
    code,使用:集装箱网络的IP地址网关为
    172.17.0.1:27017

  • 因此:


    让dbRoute=”mongodb://172.17.0.1:27017/kgp_news“

    mongo
    在node.js服务器中,您能
    ping mongo
    吗?”?和telnet到端口
    27017
    @thannguyenvan我尝试了这个结果:PING mongo.com(54.173.82.137)56(84)字节的数据。它似乎起作用了。是的。现在开始工作了。非常感谢你。现在,当使用“172.17.0.1”连接docker的任何容器时,对吗?是的,没错!它与属于服务的端口不同,但docker文档说明,如果容器位于同一用户定义的网桥网络下,则可以使用dns别名。然后运行docker容器的IP。但是,每次启动mongodb容器时,此ip都会更改。
    let dbRoute = "mongodb://<MONGODB_IP_ADDRESS>:27017/kgp_news"
    
    const option = {
        socketTimeoutMS: 30000,
        keepAlive: true,
        reconnectTries: 30000,
        useNewUrlParser: true 
    };
    
    mongoose.connect(dbRoute, option)