docker 笔记6:高级篇 DockerFile解析

这篇具有很好参考价值的文章主要介绍了docker 笔记6:高级篇 DockerFile解析。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

目录

 1.是什么?  

2.构建三步骤

3.DockerFile构建过程解析

3.1 Dockerfile内容基础知识

3.2Docker执行Dockerfile的大致流程

  总结

4.DockerFile常用保留字指令

5.案例:自定义镜像

 5.1 要求: Centos7镜像具备vim+ifconfig+jdk8

 5.2编写

5.3 准备编写Dockerfile文件  大写字母D

5.3构建

5.4再体会下UnionFS(联合文件系统)

6.虚悬镜像

6.1是什么 ?  

6.2查看 

6.3删除 

作业-自定义镜像myubuntu 


 

 1.是什么?  

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

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

 Dockerfile reference | Docker Docs

2.构建三步骤

编写Dockerfile文件

docker build命令构建镜像

docker run依镜像运行容器实例

3.DockerFile构建过程解析

3.1 Dockerfile内容基础知识

1:每条保留字指令都必须为大写字母且后面要跟随至少一个参数

2:指令按照从上到下,顺序执行

3:#表示注释

4:每条指令都会创建一个新的镜像层并对镜像进行提交

3.2Docker执行Dockerfile的大致流程

(1)docker从基础镜像运行一个容器

(2)执行一条指令并对容器作出修改

 (3)执行类似docker commit的操作提交一个新的镜像层

(4)docker再基于刚提交的镜像运行一个新容器

(5)执行dockerfile中的下一条指令直到所有指令都执行完成

  总结


从应用软件的角度来看,Dockerfile、Docker镜像与Docker容器分别代表软件的三个不同阶段,
*  Dockerfile是软件的原材料
*  Docker镜像是软件的交付品
*  Docker容器则可以认为是软件镜像的运行态,也即依照镜像运行的容器实例
Dockerfile面向开发,Docker镜像成为交付标准,Docker容器则涉及部署与运维,三者缺一不可,合力充当Docker体系的基石。

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

1 Dockerfile,需要定义一个Dockerfile,Dockerfile定义了进程需要的一切东西。Dockerfile涉及的内容包括执行代码或者是文件、环境变量、依赖包、运行时环境、动态链接库、操作系统的发行版、服务进程和内核进程(当应用进程需要和系统服务和内核进程打交道,这时需要考虑如何设计namespace的权限控制)等等;
 
2 Docker镜像,在用Dockerfile定义一个文件之后,docker build时会产生一个Docker镜像,当运行 Docker镜像时会真正开始提供服务;
 
3 Docker容器,容器是直接提供服务的。

4.DockerFile常用保留字指令

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

参考tomcat8的dockerfile入门  GitHub - docker-library/tomcat: Docker Official Image packaging for Apache Tomcat

FROM

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

MAINTAINER

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

RUN 

容器构建时需要运行的命令

两种格式 

shell格式

 
RUN yum -y install vim

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

exec格式

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

RUN是在 docker build时运行

EXPOSE

当前容器对外暴露出的端口

WORKDIR

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

USER

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

ENV

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

ENV MY_PATH /usr/mytest
这个环境变量可以在后续的任何RUN指令中使用,这就如同在命令前面指定了环境变量前缀一样;
也可以在其它指令中直接使用这些环境变量,
 
比如:WORKDIR $MY_PATH

ADD

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

 COPY

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

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器 VOLUME

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

CMD

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

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

注意

Dockerfile 中可以有多个 CMD 指令,但只有最后一个生效,CMD 会被 docker run 之后的参数替换

参考官网Tomcat的dockerfile演示讲解

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

 它和前面RUN命令的区别

CMD是在docker run 时运行。RUN是在 docker build时运行

ENTRYPOINT

也是用来指定一个容器启动时要运行的命令

类似于 CMD 指令,但是ENTRYPOINT不会被docker run后面的命令覆盖
而且这些命令行参数会被当作参数送给 ENTRYPOINT 指令指定的程序

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

 docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

是否传参    按照dockerfile编写执行    传参运行
Docker命令    docker run  nginx:test    docker run  nginx:test -c /etc/nginx/new.conf
衍生出的实际命令    nginx -c /etc/nginx/nginx.conf    nginx -c /etc/nginx/new.conf
docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器 优点 : 

在执行docker run的时候可以指定 ENTRYPOINT 运行所需的参数。

注意:

如果 Dockerfile 中如果存在多个 ENTRYPOINT 指令,仅最后一个生效。

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

5.案例:自定义镜像

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

 5.1 要求: Centos7镜像具备vim+ifconfig+jdk8

JDK的下载镜像地址:docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器小柒博客 | 开源软件镜像站

 5.2编写

5.3 准备编写Dockerfile文件  大写字母D

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

FROM centos
MAINTAINER zzyy<zzyybs@126.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-8u171-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 80
 
CMD echo $MYPATH
CMD echo "success--------------ok"
CMD /bin/bash

5.3构建

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

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

 注意,上面TAG后面有个空格,有个点

运行

docker run -it 新镜像名字:TAG

 docker run -it centosjava8:1.5 /bin/bash

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

5.4再体会下UnionFS(联合文件系统)

UnionFS(联合文件系统):Union文件系统(UnionFS)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem)。Union 文件系统是 Docker 镜像的基础。镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器
特性:一次同时加载多个文件系统,但从外面看起来,只能看到一个文件系统,联合加载会把各层文件系统叠加起来,这样最终的文件系统会包含所有底层的文件和目录

6.虚悬镜像

6.1是什么 ?  

仓库名、标签都是<none>的镜像,俗称dangling image


1 vim Dockerfile
from ubuntu
CMD echo 'action is success'
 
2 docker build .

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

6.2查看 

docker image ls -f dangling=true

命令结果

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

6.3删除 

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

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

作业-自定义镜像myubuntu 

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器 编写:准备编写DockerFile文件

docker 笔记6:高级篇 DockerFile解析,云原生技术,docker,笔记,容器

FROM ubuntu
MAINTAINER zzyy<zzyybs@126.com>
 
ENV MYPATH /usr/local
WORKDIR $MYPATH
 
RUN apt-get update
RUN apt-get install net-tools
#RUN apt-get install -y iproute2
#RUN apt-get install -y inetutils-ping
 
EXPOSE 80
 
CMD echo $MYPATH
CMD echo "install inconfig cmd into ubuntu success--------------ok"
CMD /bin/bash

构建 

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

运行文章来源地址https://www.toymoban.com/news/detail-693772.html

docker run -it 新镜像名字:TAG

到了这里,关于docker 笔记6:高级篇 DockerFile解析的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Docker容器与虚拟化技术:Dockerfile部署LNMP

    目录 一、理论 1.LNMP架构 2.背景 3.Dockerfile部署LNMP 3.构建Nginx镜像 4.构建MySQL容器 5.构建PHP镜像 6.启动 wordpress 服务  二、实验  1.环境准备 2.构建Nginx镜像 3.构建MySQL容器 4.构建PHP镜像 5.启动 wordpress 服务  三、问题 1.构建nginx镜像报错 2.构建php镜像报错 2.生成PHP镜像一直为Exit

    2024年02月04日
    浏览(52)
  • 【云原生-Docker】docker容器自定义DNS解析

    在特定的情况下,或者在网络策略特殊定义下,需要自定义dns进行域名访问,在宿主机上配置了域名解析,对于docker容器无效。 对于局域网内的域名解析,Docker 需要到 Docker 容器中配置 hosts 文件 。 docker-compose配置【推荐】 通过增加 extra_hosts 属性 进行host配置 进入容器内部

    2024年02月03日
    浏览(43)
  • 容器和云原生(二):Docker容器化技术

      目录 Docker容器的使用 Docker容器关键技术 Namespace  Cgroups UnionFS         首先直观地了解docker如何安装使用,并快速启动mysql服务的,启动时候绑定主机上的3306端口,查找mysql容器的ip,使用mysql -h containerIP 或者127.0.0.1就可以直接访问mysql服务,暂不考虑mysql的存储卷。    

    2024年02月12日
    浏览(46)
  • 云原生之深入解析Docker容器的health健康状态检查

    自 1.12 版本之后,Docker 引入了原生的健康检查实现。对于容器而言,最简单的健康检查是进程级的健康检查,即检验进程是否存活。Docker Daemon 会自动监控容器中的 PID1 进程,如果 docker run 命令中指明了 restart policy,可以根据策略自动重启已结束的容器。 在很多实际场景下,

    2024年02月09日
    浏览(51)
  • 探索云原生技术之基石-Docker容器入门篇(2)

    本博文一共有6篇,如下 探索云原生技术之基石-Docker容器入门篇(1) 探索云原生技术之基石-Docker容器入门篇(2) 探索云原生技术之基石-Docker容器入门篇(3) 等你对Docker有一定理解的时候可以看高级篇,不过不太建议。 探索云原生技术之基石-Docker容器高级篇(1) 探索云原生技术之

    2023年04月14日
    浏览(45)
  • 探索云原生技术之基石-Docker容器入门篇(1)

    本博文一共有6篇,如下 探索云原生技术之基石-Docker容器入门篇(1) 探索云原生技术之基石-Docker容器入门篇(2) 探索云原生技术之基石-Docker容器入门篇(3) 等你对Docker有一定理解的时候可以看高级篇,不过不太建议。 探索云原生技术之基石-Docker容器高级篇(1) 探索云原生技术之

    2023年04月12日
    浏览(43)
  • 探索云原生技术之基石-Docker容器入门篇(4)

    本博文一共有7篇,如下 探索云原生技术之基石-Docker容器入门篇(1) 探索云原生技术之基石-Docker容器入门篇(2) 探索云原生技术之基石-Docker容器入门篇(3) 探索云原生技术之基石-Docker容器入门篇(4) ,=由于篇幅过长,所以另起一篇 等你对Docker有一定理解的时候可以看高级篇,不

    2023年04月08日
    浏览(42)
  • 云原生之深入解析Docker容器退出码的含义和产生原因

    为什么我的容器没有运行?回答这个问题之前,需要知道 Docker 容器为什么退出?退出码会提示容器停止运行的情况? 本文列出最常见的退出码,来回答两个重要问题:这些退出码是什么意思?导致该退出码的动作是什么?exit code:代表一个进程的返回码,通过系统调用 ex

    2024年02月07日
    浏览(61)
  • 【云原生进阶之容器】第一章Docker核心技术1.1节——Docker综述

          《重识云原生系列》专题各章首节索引: 第一章——不谋全局不足以谋一域 第二章计算第1节——计算虚拟化技术总述 第三章云存储第1节——分布式云存储总述 第四章云网络第一节——云网络技术发展简述 第六章容器6.1.1节——容器综述    《云原生进阶之容器》

    2023年04月16日
    浏览(51)
  • 云原生之深入解析Docker容器的核心Cgroups的相关概念和使用实现

    Cgroups 是 Linux 系统内核提供的一种机制,这种机制可以根据需求将一些列系统任务机器子任务整合或分离到按资源划分登记的不同组内,从而为系统资源管理提供一个的框架。简单地说,Cgroups 可以限制、记录任务组所使用的物理组员(比如 CPU、Memory、IO等),为容器实现虚

    2024年02月12日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包