首页 > 代码库 > 什么是docker

什么是docker

什么是docker

官方概念

        开源的应用容器引擎

定位

         虚拟化容器,是一个单机应用

理解

         1.类似于JVM跨平台的概念,使用容器引擎解决平台依赖问题

         2.以镜像的形式发布自己的应用,运行在任何一个装有容器引擎的操作系统上

         3.类似于GITHUB,将自己的应用(镜像)发布到镜像仓库(共有/私有)中

原理

         把软件和它依赖的环境(包括操作系统和共享库等)、以来的配置文件打包在一起,以镜像的形式放到官方仓库,只要安装了容器引擎,就可以不作任何修改,运行这个软件。

分层共享+内核虚拟化实现轻量化虚拟机

       分层共享

                把一个应用分为任意多个层,比如操作系统(第一层),依赖的库和第三方软件(第二层),应用的软件包和配置文件(第三层)。如果两个应用有相同的底层,就可以共享这些层。

       内核虚拟化

                与宿主机运行在相同的linux内核,不需要指令集模拟。代表:LXC、OpenVZ、Vserver...

共享层冲突问题与解决

       问题

                如果应用A需要修改操作系统的某个配置,应用B不需要修改,改了就会出错

       解决

                给每个应用新增一个优先级最高的空白层。

                        新增A:在最上面的空白层创建一个文件A

                        删除B:在最上层,把B文件设置为不存在

                        修改C:把第一层的C文件拷贝到最上层,修改C

                拿到1.0版本,所有的增删改位于最上层,变更操作完成后,打包为新镜像,版本1.1,发布到镜像仓库中(发布时,只会发布更改的第四层,非常快速)

                技术分享

架构

         C/S架构

         docker daemon作server端,在宿主机上以后台守护进程形式运行

         client端比较灵活,可以是本机(以bin命令形式发送指令),也可以是远程(以RESTful AP的形式发送指令)

解决方案

        技术分享

docker使用流程图

        技术分享

什么是docker