微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

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

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

解决方法

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

- POSTGRES_PASSWORD=${POSTGRES_PASSWORD:-password}

根本行不通。

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

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。