目录
背景
我们之前创建自己的镜像,命令就是docker commit 。。。。
也就是我们要把自己的容器打包为一个镜像,只要修改了这个容器里面的东西,我们就需要执行命令,重新打包一下,变为一个镜像;
这个好麻烦啊,每次都要重新打包
DockerFile是什么(就是一个脚本)
·Dockerfile是用来构建Docker镜像的文本文件,是由一条条构建镜像所需的指令和参数构成的脚本。
他就是要构建一个镜像,就是多次提交commit命令,相当于批量处理
·构建三步骤
·编写Dockerfile文件
·docker build命令构建镜像
·docker run依镜像运行容器实例
Docker执行Dockerfile的大致流程
·(1)docker从基础镜像运行一个容器
·(2)执行一条指令并对容器作出修改
·(3)执行类似docker commit的操作提交一个新的镜像层
·(4)docker再基于刚提交的镜像运行一个新容器
·(5)执行dockerfile中的下一条指令直到所有指令都执行完成
DockerFile常用保留字指令
FROM
·基础镜像,当前新镜像是基于哪个镜像的,指定一个已经存在的镜像作为模板,第一条必须是from
MAINTAINER
·镜像维护者的姓名和邮箱地址
RUN
·容器构建时需要运行的命令
–两种格式
---------shell格式
RUN yum -y install vim
--------·exec格式
·RUN是在 docker build时运行
EXPOSE
·当前容器对外暴露出的端口
WORKDIR
·指定在创建容器后,终端默认登陆的进来工作目录,一个落脚点
USER
·指定该镜像以什么样的用户去执行,如果都不指定,默认是root
ENV
·用来在构建镜像过程中设置环境变量
ENV MY_PATH /usr/mytest
这个环境变量可以在后续的任何RUN指令中使用,
这就如同在命令前面指定了环境变量前缀一样;
也可以在其它指令中直接使用这些环境变量,
比如:WORKDIR $MY_PATH
ADD
·将宿主机目录下的文件拷贝进镜像且会自动处理URL和解压tar压缩包
COPY
·类似ADD,拷贝文件和目录到镜像中。
将从构建上下文目录中 <源路径> 的文件/目录复制到新的一层的镜像内的 <目标路径> 位置
·COPY src dest
·COPY ["src", "dest"]
·<src源路径>:源文件或者源目录
<dest目标路径>:容器内的指定路径,该路径不用事先建好,路径不存在的话,会自动创建。
VOLUME
·容器数据卷,用于数据保存和持久化工作
CMD
·指定容器启动后的要干的事情
·注意
·Dockerfile 中可以有多个 CMD 指令,但只有最后一个生效,CMD 会被 docker run 之后的参数替换
·参考官网Tomcat的dockerfile演示讲解
·官网最后一行命令
·我们演示自己的覆盖操作
·它和前面RUN命令的区别
·CMD是在docker run 时运行。
RUN是在 docker build时运行。
ENTRYPOINT
·也是用来指定一个容器启动时要运行的命令
·类似于 CMD 指令,但是ENTRYPOINT不会被docker run后面的命令覆盖, 而且这些命令行参数会被当作参数送给 ENTRYPOINT 指令指定的程序
·命令格式和案例说明
ENTRYPOINT可以和CMD一起用,一般是变参才会使用 CMD ,这里的 CMD 等于是在给 ENTRYPOINT 传参。
当指定了ENTRYPOINT后,CMD的含义就发生了变化,不再是直接运行其命令而是将CMD的内容作为参数传递给ENTRYPOINT指令,他两个组合会变成
案例如下:假设已通过 Dockerfile 构建了 nginx:test 镜像:
·优点
·在执行docker run的时候可以指定 ENTRYPOINT 运行所需的参数。
·注意
·如果 Dockerfile 中如果存在多个 ENTRYPOINT 指令,仅最后一个生效。
DockerFile文件build
·构建
·docker build -t 新镜像名字:TAG .
·运行
·docker run -it 新镜像名字:TAG