gpt4 book ai didi

postgresql - 将 docker-compose .yml 用于 docker swarm 时如何传递 POSTGRES_USER env 变量

转载 作者:行者123 更新时间:2023-11-29 12:09:31 25 4
gpt4 key购买 nike

我正在使用 PostgreSQL 镜像启动一个 docker swarm。我想在该数据库上创建一个名为“numbers”的用户。

这是我的 docker-compose 文件。 .env 文件包含 POSTGRES_USER 和 POSTGRES_PASSORD。如果我通过 ssh 进入托管 postgres 图像的容器,我可以在执行 env 时看到变量。但是 psql --user numbers 告诉我角色“numbers” 不存在。

我应该如何传递 POSTGRES_* 变量以便创建正确的用户?

version: '3'

services:

postgres:
image: 'postgres:9.5'
env_file:
- ./.env
ports:
- '5432:5432'
volumes:
- 'postgres:/var/lib/postgresql/data'
deploy:
replicas: 1
networks:
- default
restart: always

这会按预期创建 postgresql 用户。

 $ docker run --name some-postgres -e POSTGRES_PASSWORD=mysecretpassword -e POSTGRES_USER=numbers -d postgres

最佳答案

当Postgres发现它的数据目录已经被初始化时,他并没有运行初始化脚本。这是支票:

if [ ! -s "$PGDATA/PG_VERSION" ]; then
....

因此,我建议您手动创建该用户或从头开始(如果负担得起,请删除您的卷,丢失数据)。从命令行:

docker volume ls
docker volume rm <id>

关于postgresql - 将 docker-compose .yml 用于 docker swarm 时如何传递 POSTGRES_USER env 变量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44198512/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com