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]]

原文地址:https://www.cnblogs.com/xhj928675426/p/13124913.html