容器简史:从20世纪70年代的chroot到2016的Docker

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 本文讲的是容器简史:从20世纪70年代的chroot到2016的Docker【编者的话】作者主要介绍了从1979年到2013年容器的发展史。
本文讲的是容器简史:从20世纪70年代的chroot到2016的Docker【编者的话】作者主要介绍了从1979年到2013年容器的发展史。

今年三月份,Docker迎来了盛大的三周年庆典。 Docker 回忆录 展示了Docker是如何在我们眼前快速成长的。

尽管庆典已经结束,我将带你开启另一段旅程:在Docker开启容器大门之前虚拟化容器的历史。请走进我的时光机器,借助 Wikipedia 以及其他资源,让我们回到1979年,容器的概念被首次提出。

1979:Unix V7

1979年,我(作者)还不到10岁。在Unix V7的开发过程中,引进了 chroot 系统调用,可以重定向进程及其子进程的root目录到文件系统上的新位置。这项进步开启了进程隔离大门,使用它可以分离每个进程的文件访问权限。Chroot在1982年加入了 BSD

2000:FreeBSD Jails

经过20几年,FreeBSD Jails提供了一套微型主机环境共享系统,用来清晰地隔离服务本身与这些服务的用户。FreeBSD Jails允许管理员将一个 FreeBSD 计算机系统划分为多个独立的小型系统,称为“Jails”,并且能够为每个小型系统分配一个独立的IP地址。

2001:Linux VServer

类似于FreeBSD Jails, Linux VServer 也是一种jail机制,它能够划分计算机系统上的资源,例如文件系统、网络地址和内存。在2001年,这种操作系统虚拟化技术被写入了Linux内核,截至目前仍然能够使用,但在2006年发布了最后一个稳定版本。

2004:Oracle Solaris Containers

在2004年,Oracle发布了 Solaris Container ,其将系统资源控制与由分区提供的边界隔离结合在一起,可以在ZFS上使用快照和克隆等技术。

2005:Open VZ(Open Virtuzzo)

这是Linux上的一种操作系统级别虚拟化技术,可以使用带有补丁的Linux内核实现虚拟化、隔离、资源管理以及检查点交互。OpenVZ的代码并没有作为Linux内核官方版本一起发布。

2006:Process Containers

Process Containers (在2006年由谷歌推出),用于限制、分配和隔离进程集合中的资源使用量(包括:CPU、内存、磁盘I/O以及网络)。一年后,Process Containers被重命名为“Control Groups(cgroups)”。最终,其被合并到Linux内核2.6.24版本中。

2008:LXC

LXC(Linux Containers) 是第一个完整实现Linux容器管理的工具,其使用Cgroups和Linux命名空间,无需任何额外的补丁就能够运行在原版Linux内核之上。

2011:Warden

Warden始于2011年由CloudFoundry建立,最初使用的是LXC,随后又替换成了自己的实现方案。Warden能够在任何的操作系统上隔离环境,其以后台进程方式运行,并提供了一套容器管理API。Warden使用了C/S结构,能够在多台宿主机上进行容器管理,并且提供了一种管理Cgroups、命名空间以及进程生命周期的服务。

2013:LMCTFY

Let Me Container That For You(LMCTFY) 在2013年作为谷歌容器堆栈技术的开源版本推出,提供了Linux应用程序容器化。应用程序具备“容器意识”,能够创建和管理它们自己的容器。LMCTFY于2015年停止开发,谷歌将其核心部分贡献给Libcontainer,也就是现在的 Open Container Foundation

2013:Docker以及容器的未来

以上就是我对先于Docker的容器技术的总结。所有容器的迭代版都有它们的适用者和爱好者,但是当Docker在2013年出现时,容器的关注度爆发式地增长。Docker的发展与容器的使用一定是齐头并进的。

和Warden一样,Docker在初期同样使用了LXC,随后替换成了Libcontainer。不一样的是,Docker为容器管理构建了一个完整的生态系统,而不是专注于Libcontainer。

使用Docker,开发者能够快速地创建和运行应用程序容器。随着Docker Hub的发布,开发者能够更快地下载和运行应用程序容器。

在这三年的时间里,和多数人一样我难以想象如果没有Docker生态系统,我们该怎么进行DevOps。我非常乐意成为Docker成长旅程中的一部分,找到一种安全产品的开发方式,并将其整合到Docker生态系统。

当然,Docker不是容器唯一的未来。二月份,CoreOS发布了rkt(“rocket”的简写),其目的就是为了成为Docker的一个可靠替代品。InfoWorld中有篇 文章 提到:rkt打算和Docker做一样的事情,但他们会尽最大努力做得更好。

我的团队和我会在另外一篇文章中对容器的未来做一些预测,敬请期待。

原文链接:A Brief History of Containers: From 1970s chroot to Docker 2016(翻译:肖远昊)

原文发布时间为:2016-07-11

本文作者:肖远昊

本文来自云栖社区合作伙伴Dockerone.io,了解相关信息可以关注Dockerone.io。

原文标题:容器简史:从20世纪70年代的chroot到2016的Docker

相关文章
|
1月前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
223 77
|
12天前
|
搜索推荐 安全 数据安全/隐私保护
7 个最能提高生产力的 Docker 容器
7 个最能提高生产力的 Docker 容器
84 35
|
1月前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
11天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
17天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
90 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
1天前
|
Kubernetes Linux 虚拟化
入门级容器技术解析:Docker和K8s的区别与关系
本文介绍了容器技术的发展历程及其重要组成部分Docker和Kubernetes。从传统物理机到虚拟机,再到容器化,每一步都旨在更高效地利用服务器资源并简化应用部署。容器技术通过隔离环境、减少依赖冲突和提高可移植性,解决了传统部署方式中的诸多问题。Docker作为容器化平台,专注于创建和管理容器;而Kubernetes则是一个强大的容器编排系统,用于自动化部署、扩展和管理容器化应用。两者相辅相成,共同推动了现代云原生应用的快速发展。
24 10
|
23天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
48 3
实战~如何组织一个多容器项目docker-compose
|
1天前
|
Ubuntu NoSQL Linux
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
19 6
《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
|
17天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
44 4
|
1月前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
109 3
下一篇
开通oss服务