Ситуация:
Я создал прототип небольшого веб-приложения (node.js) и докертизировал его для целей развертывания и репликации.
Приложение говорит с запущенной MongoDB непосредственно на хосте.
Проблема:
На сервере (экземпляр AWS EC2, только порт 80 и 443 открыты) я не могу взаимодействовать с MongoDB и мне интересно, почему.
docker run --net="host" -e 'NODE_ENV=production' -e 'MONGO_URI=mongodb://USER:PASSWORD!@172.31.32.1:27017/test_db' DOCKER_IMAGE
MongoDB connected ...
Warning: connect.session() MemoryStore is not
designed for a production environment, as it will leak
memory, and will not scale past a single process.
HTTP Server started on port 80
(node:1) DeprecationWarning: current Server Discovery and Monitoring engine is deprecated, and will be removed in a future version. To use the new Server Discover and Monitoring engine, pass option { useUnifiedTopology: true } to the MongoClient constructor.
MongoNetworkError: failed to connect to server [172.31.32.1:27017] on first connect [MongoNetworkError: connection timed out
at connectionFailureError (/app/server/node_modules/mongodb/lib/core/connection/connect.js:377:14)
at Socket.<anonymous> (/app/server/node_modules/mongodb/lib/core/connection/connect.js:287:16)
at Object.onceWrapper (events.js:284:20)
at Socket.emit (events.js:196:13)
at Socket._onTimeout (net.js:432:8)
at listOnTimeout (internal/timers.js:531:17)
at processTimers (internal/timers.js:475:7) {
name: 'MongoNetworkError',
[Symbol(mongoErrorContextSymbol)]: {}
}]
at Pool.<anonymous> (/app/server/node_modules/mongodb/lib/core/topologies/server.js:433:11)
at Pool.emit (events.js:196:13)
at /app/server/node_modules/mongodb/lib/core/connection/pool.js:571:14
at /app/server/node_modules/mongodb/lib/core/connection/pool.js:994:11
at /app/server/node_modules/mongodb/lib/core/connection/connect.js:40:11
at callback (/app/server/node_modules/mongodb/lib/core/connection/connect.js:262:5)
at Socket.<anonymous> (/app/server/node_modules/mongodb/lib/core/connection/connect.js:287:7)
at Object.onceWrapper (events.js:284:20)
at Socket.emit (events.js:196:13)
at Socket._onTimeout (net.js:432:8)
at listOnTimeout (internal/timers.js:531:17)
at processTimers (internal/timers.js:475:7) {
name: 'MongoNetworkError',
[Symbol(mongoErrorContextSymbol)]: {}
}
Сначала я попытался localhost
вместо IP-адреса, но это не работает. Выдает ошибку аутентификации (что несколько странно). Поскольку для Linux 1017 * нет *, мне пришлось (временно) разрешить явный IP-адрес. IP-адрес, который я использую, я получил через :
netstat -nr | grep '^0\.0\.0\.0' | awk '{print $2}'
Мне очень странно то, что я получаю не ошибку аутентификации, а ошибку тайм-аута, поэтому мне кажется, что приложение может подключиться к пн go. Кроме того, «MonogDB connected ...» будет указывать на то, что, поскольку он создается следующей строкой в моем серверном скрипте.
mongoose
.connect(DB, { useNewUrlParser: true })
.then(console.log("MongoDB connected ..."))
.catch(err => console.log(err));
Для полноты, та же настройка (то есть dockerized app) и запуск MongoDB непосредственно на хосте) работал без проблем локально. Кроме того, я могу войти в Mon go Shell на сервере через mongo
.
Любые объяснения или советы приветствуются!