docker-compose:FATAL:用户“ postgres”的密码身份验证失败

时间:2020-10-22 01:47:53

标签: postgresql docker docker-compose postgresql-11

我的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属性以减少问题的根源,但仍然找不到问题的根源。任何人都知道为什么会发生这种情况,或者我可以使用进一步调查的步骤吗?

1 个答案:

答案 0 :(得分:0)

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

- POSTGRES_PASSWORD=${POSTGRES_PASSWORD:-password}

根本行不通。

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

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