web-dev-qa-db-ja.com

Docker AlpineLinuxコンテナのPostgres

Dockerコンテナでpostgres10.0を動作させようとしています。私は次のDockerfileを持っています:

FROM postgres:10.0-Alpine

RUN apk add openrc --no-cache

USER postgres

RUN /etc/init.d/postgresql start
RUN psql --command "IF NOT EXISTS (SELECT FROM pg_catalog.pg_user WHERE usename = 'user') THEN CREATE USER user WITH SUPERUSER ENCRYPTED PASSWORD 'password'; END IF;"
RUN createdb main

EXPOSE 5432

VOLUME  ["/etc/postgresql", "/var/log/postgresql", "/var/lib/postgresql"]

CMD ["/usr/lib/postgresql/10.0/bin/postgres", "-D", "/var/lib/postgresql/10.0/main", "-c", "config_file=/etc/postgresql/10.0/main/postgresql.conf"]

次のエラーが発生しました:

/bin/sh: /etc/init.d/postgresql: not found

のようだ /etc/init.d/postgresqlは本当に欠けています。私は何が間違っているのですか?

5
ingvar

私はこのDockerfileで終了しました:

FROM postgres:10.0-Alpine

USER postgres

RUN chmod 0700 /var/lib/postgresql/data &&\
    initdb /var/lib/postgresql/data &&\
    echo "Host all  all    0.0.0.0/0  md5" >> /var/lib/postgresql/data/pg_hba.conf &&\
    echo "listen_addresses='*'" >> /var/lib/postgresql/data/postgresql.conf &&\
    pg_ctl start &&\
    psql -U postgres -tc "SELECT 1 FROM pg_database WHERE datname = 'main'" | grep -q 1 || psql -U postgres -c "CREATE DATABASE main" &&\
    psql --command "ALTER USER postgres WITH ENCRYPTED PASSWORD 'mysecurepassword';"

EXPOSE 5432

このdockerfilecreate database'main '(存在しない場合)、postgresを開始し、デフォルトのユーザーパスワードを設定します

7
ingvar

Execコマンドを使用してそれを行うことができたので、実行中のコンテナー(この場合はAlpine 3.7)でpostgresを実行できます。注$CONTAINER_NAMEdocker psのコンテナIDです。

# Install postgresql, create user, db & start the daemon (for testing)
Sudo docker exec $CONTAINER_NAME sh -c 'apk add postgresql'
Sudo docker exec $CONTAINER_NAME  sh -c 'addgroup -S postgres && adduser -S postgres -G postgres'
Sudo docker exec $CONTAINER_NAME sh -c 'mkdir -p /var/lib/postgresql/data'
Sudo docker exec $CONTAINER_NAME sh -c 'mkdir -p /run/postgresql/'
Sudo docker exec $CONTAINER_NAME sh -c 'chown -R postgres:postgres /run/postgresql/'
Sudo docker exec $CONTAINER_NAME sh -c 'chmod -R 777 /var/lib/postgresql/data'
Sudo docker exec $CONTAINER_NAME sh -c 'chown -R postgres:postgres /var/lib/postgresql/data'
Sudo docker exec --user postgres $CONTAINER_NAME sh -c 'initdb /var/lib/postgresql/data'
Sudo docker exec --user postgres $CONTAINER_NAME sh -c 'echo "Host all  all    0.0.0.0/0  md5" >> /var/lib/postgresql/data/pg_hba.conf'
Sudo docker exec --user postgres $CONTAINER_NAME  sh -c 'pg_ctl start -D /var/lib/postgresql/data -l /var/lib/postgresql/log.log'
Sudo docker exec --user postgres $CONTAINER_NAME sh -c "psql --command \"ALTER USER postgres WITH ENCRYPTED PASSWORD 'buildpgpass';\""
Sudo docker exec --user postgres $CONTAINER_NAME sh -c "psql --command \"CREATE DATABASE builddb;\""

次のように、これをDockerfileに含めることもできます。

# Postgres
RUN apk add postgresql=11.1-r0
RUN (addgroup -S postgres && adduser -S postgres -G postgres || true)
RUN mkdir -p /var/lib/postgresql/data
RUN mkdir -p /run/postgresql/
RUN chown -R postgres:postgres /run/postgresql/
RUN chmod -R 777 /var/lib/postgresql/data
RUN chown -R postgres:postgres /var/lib/postgresql/data
RUN su - postgres -c "initdb /var/lib/postgresql/data"
RUN echo "Host all  all    0.0.0.0/0  md5" >> /var/lib/postgresql/data/pg_hba.conf
RUN su - postgres -c "pg_ctl start -D /var/lib/postgresql/data -l /var/lib/postgresql/log.log && psql --command \"ALTER USER postgres WITH ENCRYPTED PASSWORD 'postgres';\" && psql --command \"CREATE DATABASE builddb;\""

これは、その場で何かをテストしたい場合にうまく機能するようです。

3
radtek

Dockerfileには多くの問題があります。メインデータベースを作成するためのイメージを構築するときに、サーバーを起動しようとしていると思います。 dockefile内の各コマンドは独自のレイヤーで実行されるため、これは機能しません。したがって、RUN psql ...に到達すると、データベースは別のレイヤーで開始されたため、開始されません。したがって、コマンドを1行にグループ化する必要があります。

2番目の問題は、ファイル/etc/init.d/postgresqlが存在しないことです。サーバーは、postgresコマンドを使用して起動できます。

RUN postgres &\
 psql --command "IF NOT EXISTS (SELECT FROM pg_catalog.pg_user WHERE usename = 'user')\
 THEN CREATE USER user WITH SUPERUSER ENCRYPTED PASSWORD 'password'; END IF;" &\
 createdb main
2
yamenk