64

我正在尝试设置一个 postgres 容器并希望使用以下命令设置 postgres 登录:

POSTGRES_USER: docker
POSTGRES_PASSWORD: docker

所以我像这样创建了 docker-compose.yml

web:
  build: .
  ports:
    - "62576:62576"
  links:
   - redis
   - db
db:
  image: postgres
  environment:
    POSTGRES_PASSWORD: docker
    POSTGRES_USER: docker

redis:
   image: redis

我还尝试了环境变量的其他语法,将 db 部分声明为:

db:
  image: postgres
  environment:
   - POSTGRES_PASSWORD=docker
   - POSTGRES_USER=docker

但是,这些选项似乎都不起作用,因为无论出于何种原因,每当我尝试使用各种连接字符串连接到 postgres 数据库时:

postgres://postgres:postgres@db:5432/users
postgres://postgres:docker@db:5432/users
postgres://docker:docker@db:5432/users

他们都给了我身份验证失败,而不是抱怨没有用户数据库。

4

8 回答 8

82

我为此苦苦挣扎了一段时间,并没有得到接受的答案,我终于通过移除容器来让它工作:

docker-compose rm postgres

然后是音量

docker volume rm myapp_postgres

然后当我做了一个新的时,docker-compose up我看到CREATE ROLE飞过,我假设这是最初的up.


此处详细说明了其原因,在 Git repo for the Docker official image for postgres 上。

于 2017-02-04T17:58:40.567 回答
35

如果您使用的是Docker

尝试检查您的本地数据库是否处于活动状态,因为它主要与 Docker 冲突,如果是,您可以停用它或更改端口号或卸载它以避免冲突。

于 2020-01-07T15:26:55.593 回答
23

您遇到的身份验证错误将有很大帮助!

我用你的论点启动了 postgres 图像:

docker run --name db -d -e POSTGRES_PASSWORD=docker -e POSTGRES_USER=docker postgres

然后我执行:

docker exec -it db psql -U docker user
psql: FATAL:  database "user" does not exist

我收到您期望的错误消息,因为我有信任身份验证:

docker exec -it db cat /var/lib/postgresql/data/pg_hba.conf | grep -v '^#'

local   all             all                                     trust
host    all             all             127.0.0.1/32            trust
host    all             all             ::1/128                 trust
host all all 0.0.0.0/0 md5

为了模拟您的 Web 容器,我将运行另一个 postgres 容器实例并链接 db 容器,然后连接回 db 容器:

core@ku1 /tmp/i $ docker run --rm --name web --link db:db -it postgres psql -h db -Udocker user
Password for user docker: 
psql: FATAL:  password authentication failed for user "docker"

如果输入错误的密码,我会收到验证错误。但是,如果我输入正确的密码:

core@ku1 /tmp/i $ docker run --rm --name web --link db:db -it postgres psql -h db -Udocker user
Password for user docker: 
psql: FATAL:  database "user" does not exist

这一切似乎都正常工作。我把它全部放在一个 yaml 文件中,并以这种方式进行了测试:

web:
  image: postgres
  command: sleep 999
  ports:
    - "62576:62576"
  links:
   - db
db:
  image: postgres
  environment:
    POSTGRES_PASSWORD: docker
    POSTGRES_USER: docker

然后用 docker-compose 启动它:

core@ku1 /tmp/i $ docker-compose -f dc.yaml up
Creating i_db_1...
Creating i_web_1...
Attaching to i_db_1, i_web_1
db_1  | ok
db_1  | creating template1 database in /var/lib/postgresql/data/base/1 ... ok
db_1  | initializing pg_authid ... ok
db_1  | initializing dependencies ... ok
db_1  | creating system views ... ok
db_1  | loading system objects' descriptions ... ok
db_1  | creating collations ... ok
db_1  | creating conversions ... ok
db_1  | creating dictionaries ... ok
db_1  | setting privileges on built-in objects ... ok
db_1  | creating information schema ... ok
db_1  | loading PL/pgSQL server-side language ... ok
db_1  | vacuuming database template1 ... ok
db_1  | copying template1 to template0 ... ok
db_1  | copying template1 to postgres ... ok
db_1  | syncing data to disk ... ok
db_1  | 
db_1  | WARNING: enabling "trust" authentication for local connections
db_1  | You can change this by editing pg_hba.conf or using the option -A, or
db_1  | --auth-local and --auth-host, the next time you run initdb.
db_1  | 
db_1  | Success. You can now start the database server using:
db_1  | 
db_1  |     postgres -D /var/lib/postgresql/data
db_1  | or
db_1  |     pg_ctl -D /var/lib/postgresql/data -l logfile start
db_1  | 
db_1  | 
db_1  | PostgreSQL stand-alone backend 9.4.1
db_1  | backend> statement: CREATE DATABASE "docker" ;
db_1  | 
db_1  | backend> 
db_1  | 
db_1  | PostgreSQL stand-alone backend 9.4.1
db_1  | backend> statement: CREATE USER "docker" WITH SUPERUSER PASSWORD 'docker' ;
db_1  | 
db_1  | backend> 
db_1  | LOG:  database system was shut down at 2015-04-12 22:01:12 UTC
db_1  | LOG:  database system is ready to accept connections
db_1  | LOG:  autovacuum launcher started
^Z
[1]+  Stopped                 docker-compose -f dc.yaml up
core@ku1 /tmp/i $ bg

您可以看到用户和密码已创建。我执行:

core@ku1 /tmp/i $ docker exec -it i_web_1 psql -Udocker -h db user
Password for user docker: 
psql: FATAL:  password authentication failed for user "docker"
core@ku1 /tmp/i $
db_1  | FATAL:  password authentication failed for user "docker"
db_1  | DETAIL:  Connection matched pg_hba.conf line 95: "host all all 0.0.0.0/0 md5"

core@ku1 /tmp/i $ docker exec -it i_web_1 psql -Udocker -h db user
Password for user docker: 
psql: FATAL:  database "user" does not exist
db_1  | FATAL:  database "user" does not exist

所以我唯一能想到的是你试图从你的主机连接到数据库,而不是 Web 容器?或者您的 Web 容器没有使用“db”作为连接的主机?您对 Web 容器的定义不包含我可以看到的任何错误。

于 2015-04-12T22:13:16.430 回答
23

我有同样的问题,在我的情况下,问题是用一个命令解决的:

docker-compose up --force-recreate
于 2017-08-31T18:09:10.943 回答
6

这对我有帮助

docker stop $(docker ps -qa) && docker system prune -af --volumes && docker compose up
于 2020-10-13T21:31:06.043 回答
4

感谢 Bryan,docker-compose exec containername env我发现还需要删除卷。由于docker-compose volume rm volumename您需要知道确切的名称,因此删除所有内容更容易:

docker-compose down --volumes
于 2020-10-06T13:52:00.113 回答
1

我也有类似的情况。根据@Greg 的回答,我做了一个 docker -compose up,它获取了环境变量。

在此之前,我刚刚使用docker-compose run并且它没有通过运行docker-compose exec task env来获取环境变量。奇怪的是,docker-compose run task env显示了我期望的环境变量。

于 2017-06-23T18:45:24.050 回答
1

就我而言,postgres:13-alpine在 windows 10 中运行WSL2,上述解决方案都没有成功。

我的错误是我使用的 dockernetwork名称与另一个项目共享。假设我有项目 A 和 B,都具有以下结构:

myappfolder
  - docker-compose.yml
    - services
        - app
            - depends on db
        - db

碰巧,默认情况下,docker-compose名称network来自docker-compose.yml文件的父目录名称。因此,A 和 B 这两个项目都试图连接到同一个网络:myappfolder_default.

要解决这个问题:

  1. 确保网络名称在项目中是唯一的:

    一种。要么将根文件夹的名称更改为唯一

    湾。或编辑您docker-compose.yml以设置明确的网络名称

  2. 这样做docker-compose down -v 将重置您在网络中定义的所有可能的数据库 > 确保在继续之前进行 psql 转储

  3. docker-compose up

更多网络文档:https ://docs.docker.com/compose/networking/

于 2021-06-24T11:07:26.713 回答