在Docker上构建的Vapor + PostgreSQL + Nginx无法正常运行

时间:2019-08-09 01:30:52

标签: vapor vapor-fluent

我使用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或其他任何配置是否存在错误?

2 个答案:

答案 0 :(得分:4)

要连接到容器内部的数据库,请不要使用localhost作为数据库主机,而应使用您的数据库容器名称。因此,在您的情况下,主机是psql。在这里,您的docker compose格式不正确,psql和nginx必须再有一个制表符。但也许只是SO格式错误。

答案 1 :(得分:1)

泊坞窗中不能包含localhost,在这种情况下,数据库的主机为psql