我正在尝试让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
真的不见了。我做错了什么?
我完成了这个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 并设置默认用户密码
我能够使用 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;""
如果您想即时测试某些内容,这似乎效果很好。
dockerfile 存在多个问题。我猜您在构建映像以创建主数据库时正在尝试启动服务器。这是行不通的,因为 dockefile 中的每个命令都将在其自己的层中执行,因此当您到达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