我在设置docker镜像时遇到了一些问题,该镜像最终将在bitbucket管道上用于为我工作的一些API项目运行测试。
我们本地开发人员的设置非常简单,在机器上运行Java8+ Maven + PostgreSQL 9.6。
要运行集成测试,数据库必须处于运行状态。maven构建的一部分在服务器上创建必要的数据库和表。
我试着把它复制到一个docker镜像上,这就是我到目前为止得到的。
FROM maven:3.5.3-jdk-8-slim
#Install postgresql
RUN apt update && \
mkdir -p /usr/share/man/man1 &&\
mkdir -p /usr/share/man/man7 &&\
apt install -y postgresql-9.6
#Update config
RUN echo "host all all 127.0.0.1/32 trust" >> /etc/postgresql/9.6/main/pg_hba.conf
#Start server
RUN service postgresql start
#Create readonly role for DB
USER postgres
RUN psql -c "CREATE ROLE readonly"
如果我通过first run在容器中手动运行这些步骤,那么这些步骤似乎工作得很好:
docker run -it maven:3.5.3-jdk-8-slim /bin/bash
但是当我尝试构建镜像时,我得到的是:
▶ docker build -t pipelines .
Sending build context to Docker daemon 2.048kB
Step 1/6 : FROM maven:3.5.3-jdk-8-slim
---> 25f97112c73f
Step 2/6 : RUN apt update && mkdir -p /usr/share/man/man1 && mkdir -p /usr/share/man/man7 && apt install -y postgresql-9.6
---> Using cache
---> 5fa381f73c9d
Step 3/6 : RUN echo "host all all 127.0.0.1/32 trust" >> /etc/postgresql/9.6/main/pg_hba.conf
---> Using cache
---> 0721966e7749
Step 4/6 : RUN service postgresql start
---> Using cache
---> 9ca8e7a270e0
Step 5/6 : USER postgres
---> Using cache
---> 50a99c6cac20
Step 6/6 : RUN psql -c "CREATE ROLE readonly"
---> Running in 572b2b8fa754
psql: could not connect to server: No such file or directory
Is the server running locally and accepting
connections on Unix domain socket "/var/run/postgresql/.s.PGSQL.5432"?
The command '/bin/sh -c psql -c "CREATE ROLE readonly"' returned a non-zero code: 2
我读过一些关于这意味着容器试图访问主机上的端口,而不是容器的东西。但是我不能理解手动运行命令和让Dockerfile“运行”它们之间的区别。
我也尝试过从postgres:9.6
基础映像构建它,然后安装java+maven,但是当我需要在DB上创建角色时,问题是相同的。
考虑到我的意图是在bitbucket管道上使用它,我在这里做错了一些事情。
https://stackoverflow.com/questions/50844678
复制相似问题