前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >DockerFile知识点与运用

DockerFile知识点与运用

作者头像
害恶细君
发布2022-11-22 14:06:55
5050
发布2022-11-22 14:06:55
举报

本节继续学习docker容器技术,之前有使用过DockerFile来构建自己的镜像,这里总结一下常用命令。

一.DockerFile简介

DockerFile是用来构建Docker镜像的文本文件,是由一条条构建镜像所需的指令和参数构成的脚本。

在这里插入图片描述
在这里插入图片描述

DockerFile构建3步骤:1.编写Dockerfile文件 2.docker build 命令构建镜像 3.docker run使用

二.DockerFile构建过程解析

1. Dockerfile基础知识点

(1)每条保留字指令都必须为大写字母 , 并且后面要跟随至少一个参数(保留字就是run、commit等) (2)指令按照从上到下,顺序执行 (3)#表示注释 (4)每一条指令都会创建一个新的镜像层并对镜像进行提交

2.Docker执行Dockerfile构建新镜像的内部大致流程

(1)docker从基础镜像运行一个容器 (2)执行一条指令并对容器做出修改 (3)执行类似docker commit的操作提交一个的新镜像层 (4)docker再基于刚才提交的镜像运行一个新的容器 (5)执行dockerfile中的下一条指令直到所有指令都执行完成

从应用软件的角度来看,Dockerfile、Docker镜像与Docker容器分别代表软件的三个不同阶段

  • Dockerfile是软件的原材料
  • Docker镜像是软件的交付品
  • Docker容器则可以认为是软件镜像的运行态,也即依照镜像运行的容器实例

Dockerfile面向开发,Docker镜像成为交付标准,Docker容器则涉及部署与运维,三者缺一不可,合力充当Docker体系的基石。

在这里插入图片描述
在这里插入图片描述

Dockerfile,需要定义一个Dockerfile,Dockerfile定义了进程需要的一切东西。Dockerfile涉及的内容包括执行代码或者是文件、环境变量、依赖包、运行时环境、动态链接库、操作系统的发行版、服务进程和内核进程(当应用进程需要和系统服务和内核进程打交道,这时需要考虑如何设计namespace的权限控制)等等;

Docker镜像,在用Dockerfile定义一个文件之后,docker build时会产生一个Docker镜像,当运行 Docker镜像时会真正开始提供服务;

Docker容器,容器是直接提供服务的。

3.DockerFile常用保留字指令

保留字

说明

FROM

基础镜像,当前新镜像是基于哪个镜像的,指定一个已经存在的镜像作为模板,第一条必须是from

MAINTAINER

镜像维护者的姓名和邮箱地址

RUN

容器构建时需要运行的命令,两种格式。shell格式(如RUN yum -y install vim)和exec格式(如RUN [“可执行文件” ,”参数1“,“参数2”] ,eg:RUN(“./TEXT.PHP”,“dev”,“off”)),RUN是在docker builder时运行

EXPOSE

当前容器对外暴露的端口

WORKDIR

指定在创建容器后,终端默认登录的工作目录,一个落脚点

USER

指定该镜像以什么样的用户去执行,如果不指定,默认是root

ENV

用来在构建镜像的过程中设置环境变量

ADD

将宿主机目录下的文件拷贝进镜像会自动处理URL和解压tar压缩包

COPY

类似ADD,拷贝文件和目录到镜像中。将从构建上下文目录中<源路径>文件或目录复制到新的一层的镜像内的<目标路径位置>

VOLUME

容器数据卷,用于数据保存和持久化工作

CMD

指定容器启动后要干的事情

ENTRYPOINT

用来指定一个容器启动时要运行的命令,类似于CMD命令,但是ENTRYPOINT不会被docker run 后面的命令覆盖,而且,这些命令的参数会被当作参数传送给ENTRYPOINT指令指定的程序

在这里插入图片描述
在这里插入图片描述

注意:dockerfile中可以有多个CMD指令,但是只有最后一个生效。CMD会被docker run 之后的参数替代。

他和RUN命令的区别:CMD是在docker 时运行,而RUN是在docker build 时运行。

ENTRYPOINT命令格式和案例说明: 命令格式:

在这里插入图片描述
在这里插入图片描述

ENTRYPOINT可以和CMD一起用,一般是变参才会使用 CMD ,这里的 CMD 等于是在给 ENTRYPOINT 传参。

当指定了ENTRYPOINT后,CMD的含义就发生了变化,不再是直接运行其命令而是将CMD的内容作为参数传递给ENTRYPOINT指令,他两个组合会变成

在这里插入图片描述
在这里插入图片描述

案例如下:假设已通过 Dockerfile 构建了 nginx:test 镜像:

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

这里朦了没有关系,下面做一个案例体会一下。

三.案例体会

要求:自定义一个镜像,让Centos7具备vim+ifconfig+jdk8

jdk8下载地址:

在这里插入图片描述
在这里插入图片描述

可以通过wget命令获取到jdk8:

代码语言:javascript
复制
wget https://repo.huaweicloud.com/java/jdk/8u151-b12/jdk-8u151-linux-x64.tar.gz

创建编写Dockerfile文件:

代码语言:javascript
复制
vim Dockerfile
在这里插入图片描述
在这里插入图片描述

然后编写Dockerfile文件:

代码语言:javascript
复制
FROM centos:7
MAINTAINER haiexijun<haiexijun@163.com>
 
ENV MYPATH /usr/local
WORKDIR $MYPATH
 
#安装vim编辑器
RUN yum -y install vim
#安装ifconfig命令查看网络IP
RUN yum -y install net-tools
#安装java8及lib库
RUN yum -y install glibc.i686
RUN mkdir /usr/local/java
#ADD 是相对路径jar,把jdk-8u171-linux-x64.tar.gz添加到容器中,安装包必须要和Dockerfile文件在同一位置
ADD jdk-8u151-linux-x64.tar.gz /usr/local/java/
#配置java环境变量
ENV JAVA_HOME /usr/local/java/jdk1.8.0_171
ENV JRE_HOME $JAVA_HOME/jre
ENV CLASSPATH $JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib:$CLASSPATH
ENV PATH $JAVA_HOME/bin:$PATH
 
EXPOSE 8081
 
CMD echo $MYPATH
CMD echo "success--------------ok"
CMD /bin/bash

构建镜像: docker build -t 新镜像名字:TAG .

代码语言:javascript
复制
docker build -t centosjava8:1.0.0 .

注意:上面TAG后面有一个空格和一个.

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

运行镜像:

代码语言:javascript
复制
docker run -it centosjava8:1.0.0

四.虚悬镜像

有时候在创建镜像的时候产生了错误,就会产生虚悬镜像。虚悬镜像是仓库名和标签都是的镜像,俗称dangling image

在这里插入图片描述
在这里插入图片描述

虚悬镜像已经失去存在价值,可以删除。

代码语言:javascript
复制
docker image prune
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-05-22,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一.DockerFile简介
  • 二.DockerFile构建过程解析
    • 1. Dockerfile基础知识点
      • 2.Docker执行Dockerfile构建新镜像的内部大致流程
        • 3.DockerFile常用保留字指令
        • 三.案例体会
        • 四.虚悬镜像
        相关产品与服务
        容器服务
        腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档