【问题标题】:How to run Postgres in a docker Alpine Linux container?如何在 docker Alpine Linux 容器中运行 Postgres?
【发布时间】:2018-04-09 09:58:00
【问题描述】:

我正在尝试让 Postgresql 10.0 在 docker 容器中工作。我有以下 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 真的不见了。我做错了什么?

【问题讨论】:

    标签: postgresql docker alpine


    【解决方案1】:

    我完成了这个 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 -c "ALTER USER postgres WITH ENCRYPTED PASSWORD 'mysecurepassword';"
    
    EXPOSE 5432
    

    此 dockerfile 创建数据库'main'(如果不存在),启动 postgres 并设置默认用户密码

    【讨论】:

      【解决方案2】:

      我可以使用 exec 命令来执行此操作,因此我可以在正在运行的容器中运行 postgres,在本例中为 alpine 3.7。注意$CONTAINER_NAME 是来自docker 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】:

        您的 dockerfile 存在多个问题。我猜您在构建图像以创建主数据库时尝试启动服务器。这不起作用,因为 dokefile 中的每个命令都将在其自己的层中执行,因此当您到达RUN psql ... 时,数据库将不会启动,因为它是在不同的层中启动的。因此,您需要将命令组合在一行中。

        第二个问题是文件/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
        

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 2016-06-11
          • 1970-01-01
          • 1970-01-01
          • 2017-12-01
          • 1970-01-01
          • 2019-05-26
          • 1970-01-01
          • 2017-07-05
          相关资源
          最近更新 更多