[003-02-11].第11节:DockerFile解析

1.DockerFile是什么:

1.1.概念:

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

  • 2.Dockerfile官网
    在这里插入图片描述

  • 3.DockerFile在整个DOcker中的定位:可以使用DockerFile构建一个增强版的镜像
    在这里插入图片描述


1.2.构建三步骤:

  • 1.编写Dockerfile文件
  • 2.docker build命令构建镜像
  • 3.docker run依照镜像运行容器实例
    在这里插入图片描述

2.DockerFile构建过程解析:

2.1.Dockerfile内容基础知识

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

2.2.Docker执行Dockerfile的大致流程

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

2.3.总结:

  • 1.从应用软件的角度来看,Dockerfile、Docker镜像与Docker容器分别代表软件的三个不同阶段,
    • Dockerfile是软件的原材料
    • Docker镜像是软件的交付品
    • Docker容器则可以认为是软件镜像的运行态,也即依照镜像运行的容器实例
  • 2.Dockerfile面向开发,Docker镜像成为交付标准,Docker容器则涉及部署与运维,三者缺一不可,合力充当Docker体系的基石
    在这里插入图片描述
  • 3.Dockerfile,Docker镜像,Docker关系容器说明:
    • Dockerfile:需要定义一个Dockerfile,Dockerfile定义了进程需要的一切东西。Dockerfile涉及的内容包括执行代码或者是文件、环境变量、依赖包、运行时环境、动态链接库、操作系统的发行版、服务进程和内核进程(当应用进程需要和系统服务和内核进程打交道,这时需要考虑如何设计namespace的权限控制)等等;
    • Docker镜像:在用Dockerfile定义一个文件之后,docker build时会产生一个Docker镜像,当运行 Docker镜像时会真正开始提供服务;
    • Docker容器:容器是直接提供服务的。

3.DockerFile常用保留字指令:

a.介绍tomcat8的dockerfile入门

b.保留字介绍:

  • 1.FROM
    • 基础镜像,当前新镜像是基于哪个镜像的,指定一个已经存在的镜像作为模板,第一条必须是from
  • 2.MAINTAINER:
    • 镜像维护者的姓名和邮箱地
  • 3.RUN:
    • 容器构建时需要运行的命令
    • 命令有两种格式
      • shell格式: RUN yum -y install vim
      • exec格式,如下
        在这里插入图片描述
    • RUN是在 docker build时运行:
  • 4.EXPOSE
    • 当前容器对外暴露出的端口
  • 5.WORKDIR
    • 指定在创建容器后,终端默认登陆的进来工作目录,一个落脚点,即登录后去哪个工作目录;
  • 6.USER
    • 指定该镜像以什么样的用户去执行,如果都不指定,默认是root
  • 7.ENV:
    • 用来在构建镜像过程中设置环境变量
  • 8.ADD:
    • 将宿主机目录下的文件拷贝进镜像且会自动处理URL和解压tar压缩包
  • 9.COPY:
    • 类似ADD,拷贝文件和目录到镜像中。
    • 将从构建上下文目录中 <源路径> 的文件/目录复制到新的一层的镜像内的 <目标路径> 位置
      • COPY src dest
      • COPY [“src”, “dest”]
      • <src源路径>:源文件或者源目录
      • <dest目标路径>:容器内的指定路径,该路径不用事先建好,路径不存在的话,会自动创建。
  • 10.VOLUME
    • 容器数据卷,用于数据保存和持久化工作
  • 11.CMD
    • 指定容器启动后的要干的事情
    • 注意:
      • Dockerfile 中可以有多个 CMD 指令,但只有最后一个生效,CMD 会被 docker run 之后的参数替换
      • 它和前面RUN命令的区别:
        • CMD是在docker run 时运行。
        • RUN是在 docker build时运行。
  • 12.ENTRYPOINT
    • 也是用来指定一个容器启动时要运行的命令
    • 类似于 CMD 指令,但是ENTRYPOINT不会被docker run后面的命令覆盖,而且这些命令行参数会被当作参数送给 ENTRYPOINT 指令指定的程序
    • 命令格式和案例说明:
      在这里插入图片描述
    • 优点:在执行docker run的时候可以指定 ENTRYPOINT 运行所需的参数。
    • 注意:如果 Dockerfile 中如果存在多个 ENTRYPOINT 指令,仅最后一个生效。

4.案例:

4.1.初始镜像拉取运行查看:

  • 1.首先从远程仓库上拉取centos镜像:
    在这里插入图片描述
  • 2.先根据镜像启动一个容器,查看是否具有jdk8、vim等
    在这里插入图片描述
  • 3.查看启动后的容器大小:
    在这里插入图片描述

4.2.根据初始镜像打造自己的镜像:

a.打造要求:


b.编写Dockerfile:

  • 1.准备编写Dockerfile文件
    在这里插入图片描述
  • 2.Dockerfile的文件内容如下:
 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:$CLASSPATHENV PATH $JAVA_HOME/bin:$PATH EXPOSE 80 
 CMD echo $MYPATH
 CMD echo "success--------------ok"
 CMD /bin/bash

c.实现构建:

  • 1.docker build -t 新镜像名字:TAG .(注意末尾有个:.):命令是:docker build -t centosjava8:1.5 .
  • 2.还是在myfile文件目录下,执行构建Dockerfile:
    在这里插入图片描述
    在这里插入图片描述
  • 3.一定要注意,上面TAG后面有个空格,有个点
  • 4.构建后查看镜像:
    在这里插入图片描述

d.运行:

  • 1.执行命令:docker run -it 新镜像名字:TAG
    在这里插入图片描述
  • 2.测试:
    在这里插入图片描述

e.再体会下UnionFS(联合文件系统):

  • 1.UnionFS(联合文件系统):Union文件系统(UnionFS)是一种分层、轻量级并且高性能的文件系统,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem)。
  • 2.Union 文件系统是 Docker 镜像的基础。镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
  • 3.特性:一次同时加载多个文件系统,但从外面看起来,只能看到一个文件系统,联合加载会把各层文件系统叠加起来,这样最终的文件系统会包含所有底层的文件和目录

f.虚悬镜像:

  • 1.虚悬镜像是什么
    • 仓库名、标签都是<none>的镜像,俗称dangling image
    • Dockerfile写一个:
  • 2.查看:docker image ls -f dangling=true
    在这里插入图片描述
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
我想将frontend 也是用volumes,将其映射到/app/frontend目录,在/app/frontend下install以及build,如何实现 docker-compose.yml文件: version: '3' services: frontend: build: context: ./frontend dockerfile: Dockerfile ports: - 8010:80 restart: always backend: build: context: ./backend dockerfile: Dockerfile volumes: - /app/backend:/app environment: - CELERY_BROKER_URL=redis://redis:6379/0 command: python manage.py runserver 0.0.0.0:8000 ports: - 8011:8000 restart: always celery-worker: build: context: ./backend dockerfile: Dockerfile volumes: - /app/backend:/app environment: - CELERY_BROKER_URL=redis://redis:6379/0 command: celery -A server worker -l info --pool=solo --concurrency=1 depends_on: - redis - backend restart: always celery-beat: build: context: ./backend dockerfile: Dockerfile volumes: - /app/backend:/app environment: - CELERY_BROKER_URL=redis://redis:6379/0 command: celery -A server beat -l info --scheduler django_celery_beat.schedulers:DatabaseScheduler depends_on: - redis - backend restart: always redis: image: redis:latest ports: - 6379:6379 restart: always mysql: image: mysql:latest environment: - MYSQL_ROOT_PASSWORD=sacfxSql258147@ ports: - 8016:3306 volumes: - ./mysql:/var/lib/mysql restart: always frontend:dockerfile文件 FROM node:16.18.1 WORKDIR /app/frontend COPY package*.json ./ RUN npm install COPY . . RUN npm run build:prod FROM nginx:latest COPY --from=0 /app/frontend/dist/ /usr/share/nginx/html EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]
07-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值