命令
覆盖默认命令。
我的Dockerfile
FROM adoptopenjdk/maven-openjdk8
RUN mkdir /config
COPY /src/main/resources/application.properties /config/application.properties
COPY /src/main/resources/logback.xml /config/logback.xml
# copy wait-for-it-sh tool to sync container starting
COPY wait-for-it.sh /
RUN chmod +x /wait-for-it.sh
VOLUME /tmp
ADD target/my-svc-1.jar app.jar
RUN sh -c 'touch /app.jar'
ENV JAVA_OPTS=""
CMD [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /app.jar" ]
我的docker-compose.yml的有趣部分
version: '3'
services:
..
my-svc:
container_name: my-svc-container
build:
context: ./my-svc-folder
dockerfile: Dockerfile
ports:
- "9100:9100"
- "5005:5005"
depends_on:
- db
command: ["./wait-for-it.sh", "my-svc-dbserver:3306", "--", "sh", "-c", "java -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=5005 -jar /app.jar"]
...
docker-compose build的输出:
Building my-svc
Step 1/11 : FROM adoptopenjdk/maven-openjdk8
---> b3ad935008a1
Step 2/11 : RUN mkdir /config
---> Using cache
---> 5db347c13050
Step 3/11 : COPY /src/main/resources/application.properties /config/application.properties
---> Using cache
---> ade3653a018a
Step 4/11 : COPY /src/main/resources/logback.xml /config/logback.xml
---> Using cache
---> 94277fd95be1
Step 5/11 : COPY wait-for-it.sh /
---> Using cache
---> 80ac64c7c994
Step 6/11 : RUN chmod +x /wait-for-it.sh
---> Using cache
---> 1a0c99bc10ad
Step 7/11 : VOLUME /tmp
---> Using cache
---> 81864f3c9fda
Step 8/11 : ADD target/my-svc-1.jar app.jar
---> Using cache
---> 56cc5c149e37
Step 9/11 : RUN sh -c 'touch /app.jar'
---> Using cache
---> 9db3f5d983cc
Step 10/11 : ENV JAVA_OPTS=""
---> Using cache
---> a5c4828b6539
Step 11/11 : CMD [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /app.jar" ]
---> Using cache
---> cb1fd876d8d6
Successfully built cb1fd876d8d6
Successfully tagged src_my-svc:latest
因此,最后一步显示为
CMD [ "sh", "-c", "java $JAVA_OPTS -Djava.security.egd=file:/dev/./urandom -jar /app.jar" ]
,这是Dockerfile中的一个,而不是docker-compose中的一个。
我在这里想念什么?
答案 0 :(得分:3)
重载发生在运行时,即您create
基于image
的容器,然后您start
对其进行覆盖。您看到的最后一步是在实际building
的{{1}}阶段中,该阶段(正确)遵循了image
的指示。
因此,如果继续使用Dockerfile
,将要创建并启动的容器将在docker-compose up
文件中提供“覆盖”的配置。
来自Overriding Dockerfile image defaults
覆盖Dockerfile映像默认值
当开发人员从Dockerfile构建图像或提交图像时,开发人员可以设置许多默认参数,这些默认参数在图像作为容器启动时生效。 在运行时无法覆盖以下四个Dockerfile命令:
docker-compose.yaml
,FROM
,MAINTAINER
和RUN
。 其他所有内容在ADD
中都有相应的覆盖。