2016-11-14 2 views
2

https://realpython.com/blog/python/django-development-with-docker-compose-and-machine/このDockerfileに作成されるPostgresのユーザー名/パスワードはどこにありますか?だから私はこのチュートリアル以下ました

私は、すべて稼働を持っているが、私は従うか、理解できないんだということが起こっているいくつかのことをtheresの。我々が持っている主なドッカー-作曲で

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_fileがあるわかります。

DB_NAME=postgres  
DB_USER=postgres  
DB_PASS=postgres 

postgresユーザとパスワードが設定されているときに私の質問はありますか?このドッカーを実行すると、すべてが機能します。つまり、Webアプリケーションは認証情報をpostgressデータベースに渡して接続を確立できます。私はしかし、それらの資格情報が最初に設定されているところに従うことができません。

私はbase 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"] 

答えて

2

postgresのユーザーとパスワードは、公式の画像エントリポイントの23行目と同じように、entrypointに設定されていると思います。

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

あなたのエントリポイントを確認することができますか?

+0

私は公式のpostgresイメージを使用していますので、私の質問に答えたと思います。したがって、このdocker-entrypoint.shでは、設定されているユーザ名とパスワードは何ですか?私はbashスクリプトを読んでいないので、私は尋ねています。 – david

0

あなたが使っている画像はどれですか。

完全な情報についてはofficial postgres imageをご覧ください。これにより、ユーザーはの環境変数を以下のものに指定することができ、これらは実行時に簡単に無効にすることができます。

  • POSTGRES_PASSWORD
  • POSTGRES_USER
  • PGDATA
  • POSTGRES_DB

環境変数は、あなたのケースに応じて三つの方法の下に使用してオーバーライドすることができ

  • POSTGRES_INITDB_ARGS。

    • 実行イメージ:直接ドッキングウィンドウの画像を実行している場合は、-e K=Vdocker runで環境変数を含めるには、以下を使用します。あなたは下記のように指定し、Dockerfileで環境変数を指定する必要がある場合:詳細here
    docker run -e POSTGRES_PASSWORD=secrect -e POSTGRES_USER=postgres <other options> image/name 
    
    • Dockerfileのドキュメントを参照してください。詳細here
    ENV POSTGRES_PASSWORD=secrect 
    ENV POSTGRES_USER=postgres 
    
    • ドッカ - コンのドキュメントを参照してください:あなたは以下のように指定し、docker-compose.ymlで環境変数を指定する必要がある場合。詳細here
    web: 
        environment: 
        - POSTGRES_PASSWORD=secrect 
        - POSTGRES_USER=postgres 
    

    が、これは便利ですホープのドキュメントを参照してください。

  • +0

    これは実際には役に立たなかった。元の投稿をより詳細に更新しようとします。 – david

    +0

    あなたは何を試したのか、何がうまくいかないのかを詳しく説明できますか?すべてのオプションを指定し、該当するオプションを選択することができます。 – Rao

    +0

    私の質問は私の例では資格情報が設定されている場所です。私はenvファイルを持っていますが、これは私のDjangoプロジェクトがポストグルに接続するための環境変数です。 – david

    関連する問題