Dockerfile作用

官网上说Dockerfile是用来构建Docker镜像的构建文件,是由一系列命令和参数构成的脚本。

再说的明白点就是配置依赖下载镜像、配置环境变量和执行脚本的封装。

构建三步骤

dockerfile编写 python 作为基准镜像 使用 制作镜像 dockerfile基础镜像 作用_jar

docker file:就是描述需要哪些依赖、哪些环境变量、要执行哪些操作等内容。

docker 镜像 :就是通过docker build命令,根据Dockerfile的内容构建镜像。

docker 容器:将打包完的镜像作为image交给docker运行。

常用指令

FROM  指定父镜像,基于哪个镜像image构建、指定基础镜像。必须是第一个命令。

(我怎么觉得像项目的基础依赖包呢,不知道理解的对不对?)

格式:   FROM <image>   FROM <image>:<tag>   FROM <image>@<digest> 示例:   FROM mysql:5.6 注:   tag或digest是可选的,如果不使用这两个值时,会使用latest版本的基础镜像

 MAINTAINER: 维护者信息

格式: MAINTAINER <name> 示例: MAINTAINER Jasper Xu MAINTAINER sorex@163.com MAINTAINER Jasper Xu <sorex@163.com>

RUN:构建镜像时执行的命令

RUN用于在镜像容器中执行命令,其有以下两种命令执行方式: shell执行 格式: RUN <command> exec执行 格式: RUN ["executable", "param1", "param2"] 示例: RUN ["executable", "param1", "param2"] RUN apk update RUN ["/etc/execfile", "arg1", "arg1"] 注:   RUN指令创建的中间镜像会被缓存,并会在下次构建中使用。如果不想使用这些缓存镜像,可以在构建时指定--no-cache参数,如:docker build --no-cache

ADD:将本地文件添加到容器中,tar类型文件会自动解压(网络压缩资源不会被解压),可以访问网络资源,类似wget

格式: ADD <src>... <dest> ADD ["<src>",... "<dest>"] 用于支持包含空格的路径 示例: ADD hom* /mydir/ # 添加所有以"hom"开头的文件 ADD hom?.txt /mydir/ # ? 替代一个单字符,例如:"home.txt" ADD test relativeDir/ # 添加 "test" 到 `WORKDIR`/relativeDir/ ADD test /absoluteDir/ # 添加 "test" 到 /absoluteDir/

COPY:功能类似ADD,但是是不会自动解压文件,也不能访问网络资源

CMD:构建容器后调用,也就是在容器启动时才进行调用。

格式: CMD ["executable","param1","param2"] (执行可执行文件,优先) CMD ["param1","param2"] (设置了ENTRYPOINT,则直接调用ENTRYPOINT添加参数) CMD command param1 param2 (执行shell内部命令) 示例: CMD echo "This is a test." | wc - CMD ["/usr/bin/wc","--help"] 注:   CMD不同于RUN,CMD用于指定在容器启动时所要执行的命令,而RUN用于指定镜像构建时所要执行的命令。

ENV:设置环境变量

格式: ENV <key> <value> #<key>之后的所有内容均会被视为其<value>的组成部分,因此,一次只能设置一个变量 ENV <key>=<value> ... #可以设置多个变量,每个变量为一个"<key>=<value>"的键值对,如果<key>中包含空格,可以使用\来进行转义,也可以通过""来进行标示;另外,反斜线也可以用于续行 示例: ENV myName John Doe ENV myDog Rex The Dog ENV myCat=fluffy

EXPOSE:指定于外界交互的端口

格式: EXPOSE <port> [<port>...] 示例: EXPOSE 80 443 EXPOSE 8080 EXPOSE 11211/tcp 11211/udp 注:   EXPOSE并不会让容器的端口访问到主机。要使其可访问,需要在docker run运行容器时通过-p来发布这些端口,或通过-P参数来发布EXPOSE导出的所有端口

VOLUME:用于指定持久化目录

格式: VOLUME ["/path/to/dir"] 示例: VOLUME ["/data"] VOLUME ["/var/www", "/var/log/apache2", "/etc/apache2" 注:   一个卷可以存在于一个或多个容器的指定目录,该目录可以绕过联合文件系统,并具有以下功能:1 卷可以容器间共享和重用 2 容器并不一定要和其它容器共享卷 3 修改卷后会立即生效 4 对卷的修改不会对镜像产生影响 5 卷会一直存在,直到没有任何容器在使用它

WORKDIR:设置进入容器时的路径,类似于cd命令默认进入到指定目录

docker run

以下是一个小例子:

上传jar文件到服务器

[root@localhost home]# ls
eureka-server-0.0.1-SNAPSHOT.jar

新建Dockfile文件,这里没有必要与jar文件放到同目录下,build时可以指定。

touch Dockfile

[root@localhost home]# ls
Dockerfile  eureka-server-0.0.1-SNAPSHOT.jar

vi Dockfile

FROM java:8
ADD eureka-server-0.0.1-SNAPSHOT.jar app.jar
EXPOSE 8761
ENTRYPOINT ["sh","-c","java -jar /app.jar"]

生成镜像

docker build -t register2 -f Dockerfile .

注意点:

  1. Dockerfile后面的点指的是把当前目录作为上下文目录,创建镜像时,会把上下文目录的文件拷贝到镜像中。
  2. Dockerfile 文件名如果不是"Dockerfile",build的时候就需要指定,通过-f :指定要使用的Dockerfile路径。
  3. Dockerfile 文件名如果是"Dockerfile",可以默认不用指定。

查看镜像

[root@localhost home]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
register2           latest              7a8954c7f47c        About an hour ago   694MB

编码规范

  1. # 描述注释
  2. 指令必须是大家与,后面至少需要带至少一个参数
  3. 指令是按照从上到下,顺序执行