【问题标题】:Creating a docker container for postgresql with laravel sail使用 laravelsai 为 postgresql 创建一个 docker 容器
【发布时间】:2021-06-10 11:21:10
【问题描述】:

我使用标准的“image: postgres:13”创建了一个 docker 容器,但在容器内部它不会启动 postgresql,因为没有集群。可能是什么问题呢? 谢谢解答!

我的 docker-compose:

version: '3'
services:
    laravel.test:
        build:
            context: ./vendor/laravel/sail/runtimes/8.0
            dockerfile: Dockerfile
            args:
                WWWGROUP: '${WWWGROUP}'
        image: sail-8.0/app
        ports:
            - '${APP_PORT:-80}:80'
        environment:
            WWWUSER: '${WWWUSER}'
            LARAVEL_SAIL: 1
        volumes:
            - '.:/var/www/html'
        networks:
            - sail
        depends_on:
            - pgsql
    pgsql:
        image: 'postgres:13'
        ports:
            - '${FORWARD_DB_PORT:-5432}:5432'
        environment:
            PGPASSWORD: '${DB_PASSWORD:-secret}'
            POSTGRES_DB: '${DB_DATABASE}'
            POSTGRES_USER: '${DB_USERNAME}'
            POSTGRES_PASSWORD: '${DB_PASSWORD:-secret}'
        volumes:
            - 'sailpgsql:/var/lib/postgresql/data'
        networks:
            - sail
        healthcheck:
            test: ["CMD", "pg_isready", "-q", "-d", "${DB_DATABASE}", "-U", "${DB_USERNAME}"]
            retries: 3
            timeout: 5s
networks:
    sail:
        driver: bridge
volumes:
    sailpgsql:
        driver: local

我在尝试联系容器时遇到错误:

SQLSTATE[08006] [7] could not connect to server: Connection refused
    Is the server running on host "localhost" (127.0.0.1) and accepting
    TCP/IP connections on port 5432?

在容器内,当我尝试启动或重新启动 postgres 时,我收到以下消息:

[warn] No PostgreSQL clusters exist; see "man pg_createcluster" ... (warning).

【问题讨论】:

  • 标准图像正确启动。你应该提供你的 Docker Compose 文件和你运行的那些让你认为它没有启动的命令。
  • 向问题本身添加信息
  • 不需要重启 postgres。您的 Laravel 应用程序如何获取数据库地址?你不应该为你的 laravel 容器设置一个环境变量吗?因为它试图从 localhost 而不是 postgres 容器访问它。

标签: docker docker-compose postgresql-13 laravel-sail


【解决方案1】:

您不应该通过本地主机连接,而是通过容器名称作为主机名。

所以改变你的 .env 以包含

DB_CONNECTION=[what the name is in the config array]
DB_HOST=pgsql
DB_PORT=5432
DB_DATABASE=laravel
DB_USERNAME=[whatever you want]
DB_PASSWORD=[whatever you want]

【讨论】:

  • 使用 docker-compose.yml 可以避免在不同的地方定义环境变量。
  • @AymDev 这对于像用户名这样的环境变量是正确的,但是我相信主机不可能
  • 为什么不可能?它不是像其他任何环境变量一样吗?
  • 谢谢,因为一不小心,找错地方了)
  • @AymDev 实际上可以通过添加container_name 来实现
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-12-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-10-15
相关资源
最近更新 更多