• Docker_02


    1.1 Docker容器数据卷

    1.1.1 是什么?

    一句话:有点类似我们Redis里面的rdb和aof文件。就相当于一个备份文件在WEB开发可以进行热部署,正真实现开发在云端!!
    卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性:
     
    卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷

    特点:
    1:数据卷可在容器之间共享或重用数据
    2:卷中的更改可以直接生效
    3:数据卷中的更改不会包含在镜像的更新中
    4:数据卷的生命周期一直持续到没有容器使用它为止

    1.1.2 直接命令添加

    命令:

    docker run -it -v /宿主机绝对路径目录:/容器内目录 镜像名
    查看数据卷是否挂载成功你可以用docker inspect 容器ID 查看容器内部详情。

    1.1.3 DockerFile添加

    可在Dockerfile中使用VOLUME指令来给镜像添加一个或多个数据卷,这个比命令方式添加更强大,因为它可以一次性指定多个容器数据卷映射。

    # volume test
    FROM centos
    VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
    CMD echo "finished,--------success1"
    CMD /bin/bash
    

    2.1 DockerFile解析

    2.1.1 是什么?

    Dockerfile是用来构建Docker镜像的构建文件,是由一系列命令和参数构成的脚本。
    构建三步骤:

    • 编写Dockerfile文件
    • docker build生成镜像文件
    • docker run以镜像文件为模板生成对应的容器

    2.2 DockerFile构建过程解析

    2.2.1 Dockerfile内容基础知识

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

    2.2.2 Docker执行Dockerfile的大致流程

    • docker从基础镜像运行一个容器也就是FROM指令做的事情
    • 执行一条指令并对容器作出修改,每做出一个指令修改生成一层镜像。
    • 执行类似docker commit的操作提交一个新的镜像层,这个新的镜像层里套了很多层“镜像”
    • docker再基于刚提交的镜像运行一个新容器
    • 执行dockerfile中的下一条指令直到所有指令都执行完成
      总结:
      从应用软件的角度来看,Dockerfile、Docker镜像与Docker容器分别代表软件的三个不同阶段,
    • Dockerfile是软件的原材料
    • Docker镜像是软件的交付品
    • Docker容器则可以认为是软件的运行态。
      Dockerfile面向开发,Docker镜像成为交付标准,Docker容器则涉及部署与运维,三者缺一不可,合力充当Docker体系的基石。

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

    2.2.3 DockerFile体系结构(保留字指令)

    1.FROM:基础镜像,当前新镜像是基于哪个镜像的
    2.MAINTAINER:镜像维护者的姓名和邮箱地址
    3.RUN:容器构建时需要运行的命令
    4.EXPOSE:当前容器对外暴露出的端口
    5.WORKDIR:指定在创建容器后,终端默认登陆的进来工作目录,一个落脚点
    6.ENV:用来在构建镜像过程中设置环境变量
    7.ADD:将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包,比如打包自己环境的Tomcat时需要在ADD上JDK。
    8.COPY:类似ADD,拷贝文件和目录到镜像中。
    将从构建上下文目录中 <源路径> 的文件/目录复制到新的一层的镜像内的 <目标路径> 位置。
    9.VOLUME:数据容器卷用于数据保存和持久化工作。
    10.CMD:指定一个容器启动时要运行的命令,Dockerfile 中可以有多个 CMD 指令,但只有最后一个生效,CMD 会被 docker run 之后的参数替换。
    11.ENTRYPOINT :ENTRYPOINT 的目的和 CMD 一样,都是在指定容器启动程序及参数
    12.ONBUILD: 当构建一个被继承的Dockerfile时运行命令,父镜像在被子继承后父镜像的onbuild被触发.

    3.1 本地部署发布到云端

    大体操作跟玩github差不多。。。
    docker commit [OPTIONS] 容器ID [REPOSITORY[:TAG]]

  • 相关阅读:
    设计模式学习笔记——单例(Singleton)模式
    设计模式学习笔记——抽象工厂(Abstract Factory)模式
    一些C++的好书
    C++概念重载、覆盖、隐藏
    集合的子集和集合的全排列问题
    百度二面,悲剧了,附面试题,欢迎探讨。
    【翻译】ASP.NET MVC4 入门(二)添加一个Controller
    遇到问题应该多思考一下——由一个泛型方法想到的
    【翻译】ASP.NET MVC4 入门(四)添加一个Model
    我的第一篇博客——Delegate的秘密
  • 原文地址:https://www.cnblogs.com/xhj928675426/p/13124913.html
Copyright © 2020-2023  润新知