所以我遵循了这个教程:

我已经准备好了一切,但是有一些事情我无法理解.

在主Docker Compose中,我们有:

web:
  restart: always
  build: ./web
  expose:
    - "8000"
  links:
    - postgres:postgres
    - redis:redis
  volumes:
    - /usr/src/app
    - /usr/src/app/static
  env_file: .env
  command: /usr/local/bin/gunicorn docker_django.wsgi:application -w 2 -b :8000

postgres:
  restart: always
  image: postgres:latest
  ports:
    - "5432:5432"
  volumes:
    - pgdata:/var/lib/postgresql/data/

您会注意到有一个env_文件包含:

DB_NAME=postgres    
DB_USER=postgres    
DB_PASS=postgres

我的问题是何时设置postgres用户和密码?如果我运行这个docker compose everything,这意味着web应用程序可以将凭据传递到postgress数据库并建立连接.然而,我无法理解这些凭证最初是在哪里设置的.

我假设在基本postgres Dockerfile中,会有一些指令来设置数据库名称、用户名和密码.不过我不知道.下面是一份基本postgres Dockerfile的副本.

# vim:set ft=dockerfile:

FROM debian:jessie



# explicitly set user/group IDs

RUN groupadd -r postgres --gid=999 && useradd -r -g postgres --uid=999 postgres



# grab gosu for easy step-down from root

ENV GOSU_VERSION 1.7

RUN set -x \

    && apt-get update && apt-get install -y --no-install-recommends ca-certificates wget && rm -rf /var/lib/apt/lists/* \

    && wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture)" \

    && wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$(dpkg --print-architecture).asc" \

    && export GNUPGHOME="$(mktemp -d)" \

    && gpg --keyserver ha.pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4 \

    && gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu \

    && rm -r "$GNUPGHOME" /usr/local/bin/gosu.asc \

    && chmod +x /usr/local/bin/gosu \

    && gosu nobody true \

    && apt-get purge -y --auto-remove ca-certificates wget



# make the "en_US.UTF-8" locale so postgres will be utf-8 enabled by default

RUN apt-get update && apt-get install -y locales && rm -rf /var/lib/apt/lists/* \

    && localedef -i en_US -c -f UTF-8 -A /usr/share/locale/locale.alias en_US.UTF-8

ENV LANG en_US.utf8



RUN mkdir /docker-entrypoint-initdb.d



RUN apt-key adv --keyserver ha.pool.sks-keyservers.net --recv-keys B97B0AFCAA1A47F044F244A07FCC7D46ACCC4CF8



ENV PG_MAJOR 9.6

ENV PG_VERSION 9.6.1-1.pgdg80+1



RUN echo 'deb http://apt.postgresql.org/pub/repos/apt/ jessie-pgdg main' $PG_MAJOR > /etc/apt/sources.list.d/pgdg.list



RUN apt-get update \

    && apt-get install -y postgresql-common \

    && sed -ri 's/#(create_main_cluster) .*$/\1 = false/' /etc/postgresql-common/createcluster.conf \

    && apt-get install -y \

        postgresql-$PG_MAJOR=$PG_VERSION \

        postgresql-contrib-$PG_MAJOR=$PG_VERSION \

    && rm -rf /var/lib/apt/lists/*



# make the sample config easier to munge (and "correct by default")

RUN mv -v /usr/share/postgresql/$PG_MAJOR/postgresql.conf.sample /usr/share/postgresql/ \

    && ln -sv ../postgresql.conf.sample /usr/share/postgresql/$PG_MAJOR/ \

    && sed -ri "s!^#?(listen_addresses)\s*=\s*\S+.*!\1 = '*'!" /usr/share/postgresql/postgresql.conf.sample



RUN mkdir -p /var/run/postgresql && chown -R postgres /var/run/postgresql



ENV PATH /usr/lib/postgresql/$PG_MAJOR/bin:$PATH

ENV PGDATA /var/lib/postgresql/data

VOLUME /var/lib/postgresql/data



COPY docker-entrypoint.sh /



ENTRYPOINT ["/docker-entrypoint.sh"]



EXPOSE 5432

CMD ["postgres"]

推荐答案

我认为postgres的用户和密码是在entrypoint上设置的,就像官方图片entrypoint上的第23行一样.

https://github.com/docker-library/postgres/blob/e4942cb0f79b61024963dc0ac196375b26fa60dd/9.6/docker-entrypoint.sh

你能判断一下你的入口吗?

Postgresql相关问答推荐

如何获得一起满足数量要求的物品? (WHILE 循环还是 CTE?)postgresql

在Power BI和Excel中将日期格式化为正确格式

IF 块中的 CREATE FUNCTION 语句抛出错误,同时运行它自己的作品

当我写 SELECT ~1;在 Postgresql 上它给了我 -2 结果.这是什么原因?它一直持续〜4和-5等

Heroku Rails 4 无法连接到服务器:connection refused

postgres 的密码

Hibernate 将用户模型保存到 Postgres

Nodemon - 安装期间clean exit - waiting for changes before restart

在 Spring Boot 上使用 Hibernate 映射 PostGIS 几何点字段

gem install pg 无法绑定到 libpq

避免 created_at 和 updated_at 由 sequelize 自动生成

PostgreSQL:使用 psql 命令行实用程序时 Windows 上的编码问题

Rails ActiveRecord - 如何获取两个日期之间的记录

在 Spring Boot 应用程序中禁用表重新创建

子查询的自连接

如何启动 Postgres 服务器?

如何语法判断 PostgreSQL 配置文件?

向 Postgres 整数数组添加值

SQLAlchemy 声明式:定义触发器和索引 (Postgres 9)

Postgresql 用随机值更新每一行