Vit*_*aly 3 mongodb node.js docker
我在将作为 docker 容器运行的应用程序连接到 mongoDB 时遇到问题。我知道新版本 docker-compose 不推荐使用“链接”,所以我尝试使用自定义网络。我的 docker-compose.yml:
version: "3.3"
services:
app:
container_name: app
build: ./app
depends_on:
- "mongodb"
networks:
- my-network
command: pm2-docker start pm2.config.js --watch
volumes:
- ./app/logs:/opt/app/logs
- ./app:/opt/app
ports:
- "3010:80"
mongodb:
image: mongo
container_name: mongodb
restart: always
environment:
MONGO_INITDB_ROOT_PASSWORD: pw
MONGO_INITDB_ROOT_USERNAME: login
MONGO_INITDB_DATABASE: dbname
volumes:
- ./mongodb/db:/data/db
ports:
- "27017:27017"
networks:
- my-network
networks:
my-network:
driver: bridge
Run Code Online (Sandbox Code Playgroud)
我的应用程序的 Dockerfile:
FROM node:10.7.0
RUN npm i -g pm2
RUN pm2 install pm2-logrotate \
&& pm2 set pm2-logrotate:max_size 50M \
&& pm2 set pm2-logrotate:compress true \
&& pm2 set pm2-logrotate:workerInterval 60
RUN mkdir -p /tmp
COPY package*.json /tmp/
RUN cd /tmp \
&& npm i \
&& npm cache clean --force
RUN mkdir -p /opt/app && cp -a /tmp/node_modules /opt/app/
WORKDIR /opt/app
COPY . /opt/app/
VOLUME [ "/opt/app/logs/" ]
ENV PORT 80
ENV MONGODB_AUTH mongodb://login:pw@127.0.0.1:27017/dbname
EXPOSE 80
CMD [ "pm2-docker", "start", "pm2.config.js", "--env", "production" ]
Run Code Online (Sandbox Code Playgroud)
当我运行时MongoClient.connect(process.env.MONGODB_AUTH, { useNewUrlParser: true });,我在我的应用程序中收到以下错误消息:
MongoNetworkError:第一次连接时无法连接到服务器 [127.0.0.1:27017] [MongoNetworkError: connect ECONNREFUSED 127.0.0.1:27017]
我无法理解我做错了什么。这是控制台输出docker network ls:
NETWORK ID NAME DRIVER SCOPE
4731ec3d6886 bridge bridge local
e5a6bf78bd5f docker_gwbridge bridge local
aae21167a37a host host local
d6ba0dfe01a3 myproject_default bridge local
34af02bd434d myproject_my-network bridge local
5911111233bf none null local
Run Code Online (Sandbox Code Playgroud)
这是输出docker network inspect myproject_my-network:
[
{
"Name": "myproject_my-network",
"Id": "34af02bd434d7fe8b6755f584b45eeb0a47fafb087d7f44023598d6ae8bb79a4",
"Created": "2018-08-05T22:21:06.938675177+03:00",
"Scope": "local",
"Driver": "bridge",
"EnableIPv6": false,
"IPAM": {
"Driver": "default",
"Options": null,
"Config": [
{
"Subnet": "172.20.0.0/16",
"Gateway": "172.20.0.1"
}
]
},
"Internal": false,
"Attachable": true,
"Ingress": false,
"ConfigFrom": {
"Network": ""
},
"ConfigOnly": false,
"Containers": {},
"Options": {},
"Labels": {
"com.docker.compose.network": "my-network",
"com.docker.compose.project": "myproject"
}
}
]
Run Code Online (Sandbox Code Playgroud)
当我尝试使用 172.20.0.1 而不是 127.0.0.1 时,我得到了同样的错误。我很高兴为我的问题提供任何帮助
您似乎在名为mongodb.
MongoDB 正在侦听容器的 27017 端口,您的容器将其发布到主机的 27017 端口。
但是在您的应用程序容器内,没有应用程序在 localhost 的端口 27017 上侦听。
所以你的错误是正常的,你不应该以这种方式连接到mongo。相反,您可以尝试:
ENV MONGODB_AUTH mongodb://login:pw@mongodb:27017/dbname
不过,您仍然需要mongodb://login:pw@127.0.0.1:27017/dbname从您的主机访问 mongo 。
docker compose 文档中有一个示例:
在 Web 容器中,您到 db 的连接字符串看起来像 postgres://db:5432,而在主机上,连接字符串看起来像 postgres://{DOCKER_IP}:8001。来自https://docs.docker.com/compose/networking/
| 归档时间: |
|
| 查看次数: |
6176 次 |
| 最近记录: |