【问题标题】:docker-compose: FATAL: password authentication failed for user "postgres"docker-compose:致命:用户“postgres”的密码验证失败
【发布时间】:2020-10-22 01:47:53
【问题描述】:

我的 docker-compose 设置中用于 postgres:11 的 docker 容器正在运行。

每当我尝试通过 POSTGRES_USER / POSTGRES_PASSWORD 来覆盖 postgres:password 的默认组合时,我都会收到以下错误:

postgres    | 2020-10-22 01:33:33.759 UTC [72] FATAL:  password authentication failed for user "postgres"
postgres    | 2020-10-22 01:33:33.759 UTC [72] DETAIL:  Role "postgres" does not exist.

这里是 docker-compose 设置:

version: '3.4'

services:
  postgres:
    image: postgres:11
    container_name: postgres
    ports:
      - "5432:5432"
    environment:
      - POSTGRES_DB=orca
      - POSTGRES_USER=${POSTGRES_USER:-postgres}
      - POSTGRES_PASSWORD=${POSTGRES_PASSWORD:-password}
      - POSTGRES_SCHEMA=clinics

命令:

POSTGRES_USER=arthur POSTGRES_PASSWORD=password docker-compose -f docker-compose.development.yml up

仅覆盖 docker-compose 之外的 docker 容器本身不会导致相同的问题。以下命令不会导致相同的错误。

$ docker container run -e POSTGRES_USER=arthur -e POSTGRES_PASSWORD=password -e POSTGRES_DB=orca -e POSTGRES_SCHEMA=clinics postgres:11

我已经删除了volumesenv_file 属性以减少问题的根源,但我仍然找不到问题的根源。有人知道为什么会发生这种情况或我可以用来进一步调查的步骤吗?

【问题讨论】:

    标签: postgresql docker docker-compose postgresql-11


    【解决方案1】:

    Docker compose 不支持 bash 或其他 shell 功能。您尝试为环境变量设置默认值的方式:

    - POSTGRES_PASSWORD=${POSTGRES_PASSWORD:-password}
    

    根本行不通。

    尝试按照here 的说明使用简单的环境变量替换。

    您可以在执行命令时从 docker compose 文件中进行默认设置。

    【讨论】:

    • 感谢您的回答!我明天试试。这对我来说很奇怪,因为这以前有效(或者偶然看起来确实有效),而且我没有足够的 bash 知识来提出这种语法 - 它来自我之前的 docker-compose 示例跨越。