1、FROM
2、RUN
3、CMD ["executable","param1","param2"] \ ["param1","param2"] \ command param1 param2: DockerFile中只有一个CMD,多于一个将执行最后一个。它的意思差不多就是启动容器后执行的默认命令。
4、LABEL
5、EXPOSE
6、ADD [--chown=WORKDIR
/relativeDir/
ADD test /absoluteDir/ # 添加 "test" 到 /absoluteDir/
ADD --chown=55:mygroup files* /somedir/
ADD --chown=bin files* /somedir/
7、COPY [--chown=
ENTRYPOINT ["executable", "param1", "param2"] / command param1 param2: 容器启动后执行该命令。如果定义ENTRYPOINT 那么CMD形式就变为CMD ["param1","param2"] json数组中变为ENTRYPOINT的第一个参数和第二个参数
ARG VERSION=latest FROM alpine:$VERSION ENTRYPOINT ["ls", "-la"] ENTRYPOINT与CMD的比较
当有多个ENTRYPOINT CMD它们都只执行最后一个 当容器为一个可执行文件时应该定义ENTRYPOINT 当同时定义ENTRYPOINT 和 CMD时,CMD为ENTRYPOINT的默认参数 当docker执行run命令时,在里面指定CMD时,CMD将会被重写。 VOLUME ["/data"]: 在制作镜像时挂载卷。会在宿主机上自动生成一个对应的共享目录。 RUN mkdir /data1 RUN touch /data1/2a.txt VOLUME /data1
通过命令 docker inspect hasVvolume "Mounts": [ { "Type": "volume", "Name": "0d63fcdf621ee728bb85dfcc2b30f3acddf6489a0e93b81ced17f05860497321", "Source": "/var/lib/docker/volumes/0d63fcdf621ee728bb85dfcc2b30f3acddf6489a0e93b81ced17f05860497321/_data", "Destination": "/data1", "Driver": "local", "Mode": "", "RW": true, "Propagation": "" } ]
也可以通过 docker run -v 来挂载共享目录,这时 Source 指出 -v 时定义的目录 "Mounts": [ { "Type": "bind", "Source": "/Users/zhangbo/Desktop/data1", "Destination": "/data1", "Mode": "", "RW": true, "Propagation": "rprivate" } ] 容器中共享目录
8、使用 --volumes-from,达到容器中文件夹共享
docker run -itd --name noVvolume-v-1 --volumes-from noVvolume-v 48cd9e43b6a9
USER
Step / : RUN echo $user1 ---> Running in a56a602a8f87 zhang bo Removing intermediate container a56a602a8f87 ---> 3e9c6ec19129 Step / : RUN echo $buildno ---> Running in 6598768a1080 预制变量
FROM ubuntu ARG CONT_IMG_VER ENV CONT_IMG_VER $ RUN echo $CONT_IMG_VER
9、可以通过 --build-arg 标签进行给定的预制的变量。--build-arg
评论区