Dockerfile是用来构建镜像的文件。
步骤:
1、编写dockerfile文件。
2、docker build 运行文件。
3、docker run 运行镜像。
4、docker push 仓库,将镜像上传到镜像库。
基础:
1、保留关键字都必须是大写(指令)。
2、执行顺序从上到下。
3、每个指令都会创建一个新的镜像层,并提交。
常用命令
关键字 | 作用 | 备注 |
---|---|---|
FROM | 指定父镜像 | 指定dockerfile基于那个image构建 |
MAINTAINER | 作者信息 | 用来标明这个dockerfile谁写的 |
LABEL | 标签 | 用来标明dockerfile的标签 可以使用Label代替Maintainer 最终都是在docker image基本信息中可以查看 |
RUN | 执行命令 | 执行一段命令 默认是/bin/sh 格式: RUN command 或者 RUN ["command" , "param1","param2"] |
CMD | 容器启动命令 | 提供启动容器时候的默认命令 和ENTRYPOINT配合使用.格式 CMD command param1 param2 或者 CMD ["command" , "param1","param2"] |
ENTRYPOINT | 入口 | 一般在制作一些执行就关闭的容器中会使用 |
COPY | 复制文件 | build的时候复制文件到image中 |
ADD | 添加文件 | build的时候添加文件到image中 不仅仅局限于当前build上下文 可以来源于远程服务 |
ENV | 环境变量 | 指定build时候的环境变量 可以在启动的容器的时候 通过-e覆盖 格式ENV name=value |
ARG | 构建参数 | 构建参数 只在构建的时候使用的参数 如果有ENV 那么ENV的相同名字的值始终覆盖arg的参数 |
VOLUME | 定义外部可以挂载的数据卷 | 指定build的image那些目录可以启动的时候挂载到文件系统中 启动容器的时候使用 -v 绑定 格式 VOLUME ["目录"] |
EXPOSE | 暴露端口 | 定义容器运行的时候监听的端口 启动容器的使用-p来绑定暴露端口 格式: EXPOSE 8080 或者 EXPOSE 8080/udp |
WORKDIR | 工作目录 | 指定容器内部的工作目录 如果没有创建则自动创建 如果指定/ 使用的是绝对地址 如果不是/开头那么是在上一条workdir的路径的相对路径 |
USER | 指定执行用户 | 指定build或者启动的时候 用户 在RUN CMD ENTRYPONT执行的时候的用户 |
HEALTHCHECK | 健康检查 | 指定监测当前容器的健康监测的命令 基本上没用 因为很多时候 应用本身有健康监测机制 |
ONBUILD | 触发器 | 当存在ONBUILD关键字的镜像作为基础镜像的时候 当执行FROM完成之后 会执行 ONBUILD的命令 但是不影响当前镜像 用处也不怎么大 |
STOPSIGNAL | 发送信号量到宿主机 | 该STOPSIGNAL指令设置将发送到容器的系统调用信号以退出。 |
SHELL | 指定执行脚本的shell | 指定RUN CMD ENTRYPOINT 执行命令的时候 使用的shell |
创建自定义镜像并运行容器
# 创建存放dockerfile文件的目录
[root@10-9-1-10 home]# mkdir dockerfile-test
[root@10-9-1-10 home]# cd dockerfile-test/
# 编辑dockerfile_01文件
[root@10-9-1-10 dockerfile-test]# vim dockerfile_01
# 源镜像名称
FROM centos
# 作者信息
MAINTAINER hanzhishun<lpphan@163.com>
# 环境变量
ENV MYPATH /usr/local
# 工作目录
WORKDIR $MYPATH
# 执行安装组件
RUN yum -y install vim
RUN yum -y install net-tools
# 暴漏端口
EXPOSE 80
# 输出工作目录
CMD echo $MYPATH
# 匿名挂在两个镜像目录
VOLUME ["volume01","volume02"]
# 输出信息
CMD echo "===========END========="
# 使用bash工具运行
CMD /bin/bash
创建镜像
[root@10-9-1-10 dockerfile-test]# docker build -f dockerfile_01 -t hanzhishun/centos01:1.0 .
运行自定义镜像
[root@10-9-1-10 dockerfile-test]# docker run -it --name centos-han hanzhishun/centos01:1.0
[root@34ee15e69515 /]# ls
bin dev etc home lib lib64 lost+found media mnt opt proc root run sbin srv sys tmp usr var volume01 volume02
# 测试挂载目录
[root@34ee15e69515 /]# cd volume01
[root@34ee15e69515 volume01]# vi test
# 查看容器
[root@10-9-1-10 dockerfile-test]# docker inspect 34ee15e69515
本博客的部署方法
-
将项目打成jar包
-
创建dockerfile,将jar包放在同级
#指定基础镜像 FROM java:8-apline #拷贝本地文件到镜像的指定目录 并改名 ADD ./docker.jar app.jar # 暴露端口 EXPOSE 8080 ENTRYPOINT ["java","-jar","/hsjz.jar"]
-
执行构建命令
docker build -f ./${dockerFile} -t app .(.表示最后版本)
-
运行镜像文件
docker run -itd \ -p 80:8090 \ -v $PWD/ik:/root/.halo \(挂载到用户的halo运行目录) halo
评论区