Docker MongoNetworkError: истекло время ожидания соединения при сборке Node JS App от docker - PullRequest
0 голосов
/ 10 июля 2019

Не удается подключиться к Mongodb. То, что установлено Docker

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

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

mongoose.connect(dbRoute, option)

Устанавливаю монго через докер. Это запустить порт 27017.

А когда я запускаю проект скриптом "node index.js". это работает.

Но когда я создаю приложение, пишу Dockerfile. Не удается подключиться к Монго. 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.

Ответы [ 2 ]

0 голосов
/ 10 июля 2019

mongo были установлены на container, поэтому убедитесь, что:

  1. Expose 27017 порт при запуске для сборки container,

    docker run -p 27017:27017 ....

  2. В node коде, подключитесь к mongo контейнеру, используя: IP-адрес шлюза контейнерной сети: 172.17.0.1:27017

Итак:

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

0 голосов
/ 10 июля 2019

используется localhost контейнера докера.

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

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

mongoose.connect(dbRoute, option)

Или вы можете указать IP-адрес контроллера mongodb.Чтобы получить IP от mongodb conatiner, используйте $ 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)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...