我使用docker组成项目的Vapor,PostgreSQL和Nginx,我的docker-compose.yml像这样:
version: "3.6"
services:
vapor:
build:
context: ./vapor
image: ${CURRENT_VAPOR_IMG}
ports:
- 8080:8080
volumes:
- ${HOST_ROOT}:${CONTAINER_ROOT}
working_dir: ${CONTAINER_ROOT}
tty: true
entrypoint: bash
networks:
- x-net
nginx:
build:
context: ./nginx
image: ${CURRENT_NGINX_IMG}
ports:
- ${HOST_HTTP_PORT}:80
volumes:
- ${HOST_ROOT}:${CONTAINER_ROOT}
networks:
- x-net
psql:
image: ${CURRENT_DB_IMG}
ports:
- 5432:5432
environment:
- POSTGRES_DB=xxx
- POSTGRES_USER=xxx
- POSTGRES_PASSWORD=pass
volumes:
- ~/x/x-db:/var/lib/postgresql/data
networks:
- x-net
networks:
x-net:
driver: bridge
我通过运行docker-compose启动所有容器,然后进入vapor的容器以构建&&运行项目后,它将向控制台提示错误:
NIO.ChannelError.connectFailed(NIO.NIOConnectionError(host: "localhost", port: 5432, dnsAError: nil, dnsAAAAError: nil, connectionErrors: [NIO.SingleConnectionFailure(target: [IPv6]localhost/::1:5432, error: connection reset (error set): Connection refused (errno: 61)), NIO.SingleConnectionFailure(target: [IPv4]localhost/127.0.0.1:5432, error: connection reset (error set): Connection refused (errno: 61))]))
然后,我在本地计算机上运行vapor项目并保持psql容器运行,它正常工作,例如完成了模型的第一次迁移。
我的docker或其他任何配置是否存在错误?
答案 0 :(得分:4)
要连接到容器内部的数据库,请不要使用localhost作为数据库主机,而应使用您的数据库容器名称。因此,在您的情况下,主机是psql。在这里,您的docker compose格式不正确,psql和nginx必须再有一个制表符。但也许只是SO格式错误。
答案 1 :(得分:1)
泊坞窗中不能包含localhost
,在这种情况下,数据库的主机为psql
。