是什么
简单的说Docker是一个构建在LXC之上的,基于进程容器(Processcontainer)的轻量级VM解决方案。
拿现实世界中货物的运输作类比, 为了解决各种型号规格尺寸的货物在各种运输工具上进行运输的问题,我们发明了集装箱
Docker的初衷也就是将各种应用程序和他们所依赖的运行环境打包成标准的container/image,进而发布到不同的平台上运行
从理论上跟各种虚拟机Image也起着类似的作用
Docker container和普通的虚拟机Image相比, 最大的区别是它并不包含操作系统内核.
普通虚拟机将整个操作系统运行在虚拟的硬件平台上, 进而提供完整的运行环境供应用程序运行, 而Docker则直接在宿主平台上加载运行应用程序. 本质上他在底层使用LXC启动一个Linux Container,通过cgroup等机制对不同的container内运行的应用程序进行隔离,权限管理和quota分配等
每个container拥有自己独立的各种命名空间(亦即资源)包括:
PID 进程, MNT 文件系统, NET 网络, IPC , UTS 主机名等
与LXC有什么不同
基本上你可以认为目前的Docker是LXC的一个高级封装,提供了各种辅助工具和标准接口方便你使用LXC,你可以依靠LXC和各种脚本实现与docker类似的功能,就像你不使用APT/yum等工具也可以自己搞定软件包安装一样,你使用他们的关键原因是方便易用!
实际使用中,你一般不用关心底层LXC的细节,同时也不排将来docker实现基于非LXC方案的可能性
在LXC的基础上, Docker额外提供的Feature包括:标准统一的打包部署运行方案, 历史版本控制, Image的重用,Image共享发布等等
Container构建方案
除了LXC,Docker的核心思想就体现在它的运行容器构建方案上
为了最大化重用Image,加快运行速度,减少内存和磁盘footprint, Docker container运行时所构造的运行环境,实际上是由具有依赖关系的多个Layer组成的。例如一个apache的运行环境可能是在基础的rootfs image的基础上,叠加了包含例如Emacs等各种工具的image,再叠加包含apache及其相关依赖library的image,这些image由AUFS文件系统加载合并到统一路径中,以只读的方式存在,最后再叠加加载一层可写的空白的Layer用作记录对当前运行环境所作的修改。
有了层级化的Image做基础,理想中,不同的APP就可以既可能的共用底层文件系统,相关依赖工具等,同一个APP的不同实例也可以实现共用绝大多数数据,进而以copy on write的形式维护自己的那一份修改过的数据等
历史和生态环境
2013.01 做为dotcloud内部项目开始启动
2013.03.27 正式作为public项目发布
2014.1 被BLACK DUCK 评选为2013年10大开源新项目“TOP 10 OPEN SOURCE ROOKIE OF THE YEAR”
目前的状态 ( 2014.3 )
Docker 0.8.1
10000+ github stars(top 50)
350+ contributors
1500+ fork
具体应用方面,可以看到百度至少在2013年10月份就已经成功使用Docker支持其BAE平台的Paas服务。
相关推荐
Docker 可以让开发者打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。 在本压缩包 "docker-20.10_install...
【描述】 Docker-oo 是一个基于 Docker 的容器化解决方案,它提供了一种高效、灵活的方式来部署和管理应用程序。源码分析将帮助我们深入了解 Docker-oo 如何利用 Docker 的核心特性,以及它是如何实现容器编排和管理...
这个版本适用于Mac操作系统,提供了一种轻量级的虚拟化解决方案,让用户能够在Mac上运行容器化应用。 Docker是容器化技术的代表,它允许开发者将应用程序及其依赖打包成独立的、可移植的容器,以便在各种环境中无缝...
Docker是一个开源的应用容器引擎,它允许开发者打包他们的应用及其依赖环境到一个可移植的容器中,然后发布到任何流行的Linux或Windows机器上,也可以实现虚拟化。而Docker Compose是Docker的一个工具,用于定义和...
Docker 容器技术是一种轻量级的虚拟化技术,它可以提供快速、灵活和可靠的应用程序部署解决方案。 知识点: 1. 虚拟化技术分类:系统虚拟化和进程虚拟化。 2. Docker 容器技术的核心:Docker 守护进程。 3. Docker...
离线一键部署与卸载Docker是针对网络环境有限或者不稳定情况下的解决方案,它使得用户无需连接到互联网就能完成Docker的安装与移除过程。本文将详细介绍如何使用提供的资源来实现这一目标。 首先,我们需要了解...
Docker作为一种先进的容器化解决方案,解决了传统虚拟化技术存在的问题,提高了资源利用率并简化了应用程序的部署流程。通过对Docker的学习和应用,开发者可以更高效地管理应用程序及其运行环境,从而加速软件交付...
该解决方案主要包括容器虚拟化安全、容器安全管理和容器网络安全三个方面。 一、从虚拟化安全到容器安全 传统虚拟化技术是一种实现硬件基础设施资源的充分利用、合理分配和有效调度的重要技术手段。在基于 ...
Docker 提供了一个轻量级的虚拟化解决方案,可以帮助开发者快速地创建、部署和管理容器。Docker 配置可以帮助您快速地创建一个可用的 Docker 环境。 在本教程中,我们将使用 Docker 配置来创建一个可用的 Docker ...
这些驱动程序可以是针对本地虚拟化的解决方案(如 VirtualBox 或 Hyper-V),也可以是面向云服务提供商的接口(如 AWS、Azure 或 GCP)。这种方式极大地增强了 Docker Machine 的灵活性与适用范围。 #### 安装 ...
- **背景**:xhyve 是 macOS 的一个虚拟化解决方案,它基于 FreeBSD 的 bhyve 虚拟化技术。bhyve 类似于 VMware 和 KVM,提供了一种在操作系统内核级别运行虚拟机的能力。 - **特点**:xhyve 具有原生性能,因为它...
Jitsi Meet是一款开源的、基于Web的视频会议系统,它提供了安全、可扩展且易于部署的解决方案,适用于远程工作、在线教育和虚拟社交活动。"docker-jitsi-meet-stable-7882.zip" 是一个专门为Docker设计的Jitsi Meet...
而ue4_docker项目就是为了解决这个问题,它提供了在Docker容器中运行UE4的解决方案。 ue4_docker-0.0.66-py3-none-any.whl文件是一个Python轮子文件,它是Python的二进制包格式,主要用于简化Python库的安装过程。...
Linux容器虚拟技术(LXC)是一种轻量级的虚拟化技术,它可以提供轻量级的虚拟化解决方案。LXC可以提供以下几个方面的隔离: * 进程隔离:LXC可以独立地运行自己的进程,不受宿主机的影响。 * 资源隔离:LXC可以提供...
容器虚拟化主要基于操作系统虚拟化,Docker 架构是:物理机 -> 宿主机操作系统 -> Docker 引擎 -> 应用程序。容器虚拟化技术可以为一组进程分配独立的运行环境,限制他们能使用的资源,并防止进程之间互相干扰。 ...
【描述】描述中提到的“通用php+mysql+nginx包”指的是一个组合了这三个关键组件的Docker化解决方案。Docker Compose允许通过一个配置文件(docker-compose.yml)来定义和管理多个容器,简化了多服务应用的部署过程...
Docker是一种轻量级的操作系统虚拟化工具,能够使应用程序与基础设施相隔离,提供了一个高效、轻量级的虚拟化解决方案。下面是Docker笔记的详细知识点: 一、Docker安装 Docker的安装非常简单,只需要在Linux系统...
它提供了全面的数据治理解决方案,特别适用于大数据环境中的企业级应用。 3. **数据治理**: 数据治理涉及数据的质量、安全、生命周期管理以及合规性。Apache Atlas是数据治理的重要工具,它可以帮助组织理解和控制...
Docker容器轻量级且独立,可以确保AirConnect在不同环境中的一致运行。 2. **AirPlay**: AirPlay是由Apple开发的无线媒体流协议,用于在Apple设备之间传输音频、视频和照片。Docker-AirConnect使得非Apple设备如...