容器是什么?

在我看来,容器就是一种特殊的进程。

想象一下,我们在运行一段程序时发生了什么?大体的过程可以分为如下几步:

  1. 操作系统从程序中读取数据,将数据加载到内存中待命;
  2. 操作系统从程序中读取指令,指示 CPU 完成操作;
  3. CPU 与内存写作进行数据处理,同时,使用寄存器存放数值,使用内存堆栈保存执行的命令和变量;
  4. 计算机中相关的文件和 I/O 设备更新状态;

进程是资源分配的最小单位。在上面的过程中,一旦“程序”被执行,它就从磁盘上的二进制文件,变成了计算机内存中的数据、寄存器里的值、堆栈中的指令、被打开的文件,以及各种设备的状态信息的一个集合。像这样一个程序运行起来后的计算机执行环境的总和,就是一个进程。

容器技术的核心功能,就是通过约束和修改进程的动态表现,从而为其创造一个“边界”。

对于进程而言,它所能使用的资源就是宿主机为它分配的资源,一般来说,就是整个宿主机所有的资源,而它的进程视图,也就是宿主机内所有进程的运行状态,对于资源管理来说,这是一种非常简单粗暴的方式。有时候,我们想要对资源进行管理,比如,我们想要为进程 A 分配指定大小的资源,首先,我们可以采用在程序内指定数值的方式进行控制,但是这样一来,第一,增加了开发的成本,第二,修改起来也比较麻烦,这时候,使用容器进行管理就方便多了。那么,容器是如何做到的呢?

容器有两个非常关键的技术,一个叫做 Cgroups 技术,用来制造约束,另一个叫做 Namespace 技术,用来修改进程视图。

首先,我们来介绍 Namespace 技术。假设,我们现在宿主机上用容器运行一个程序,在宿主机上,我们看到,容器的进程 ID 是 N,而在容器中,我们会发现,程序的进程 ID 是 1,即对于程序而言,它是这个容器的第一个进程,假设现在我们的用户量增加了,需要创建一个新的进程,当我们用 clone() 系统调用一个新的进程,会发现,这个新的进程的进程 ID 也是 1,即在容器中运行了两个相同的进程 ID,这在真实的宿主机中当然不可能,但是在容器中,却可以通过 Namespace 技术修改进程视图。值得一提的是,除了 PID Namespace,Linux 操作系统还提供了 Mount、Uts、IPC、Network Namespace 和 User Namespace,用来对各种不同的进程上下文进行修改。

接下来,我们来介绍 Cgroups 技术。首先,我们来介绍容器的“隔离”。前面我们讲到,容器就是一种特殊的进程,这个特殊的进程相比于传统的虚拟机,额外的资源占用几乎为零,这就确保了容器化的“敏捷”和“高性能”,但是,也正因为容器只是一种特殊的进程,所以不同容器必须同享同一个宿主机的操作系统内核。其次,在 Linux 内核中,有很多资源和对象是不能被 Namespace 化的,最典型的例子就是:时间。最后,也是最重要的,在生产环境中,不能确保运行在物理机的 Linux 容器的安全性,或者说,确保安全性的成本过高,因此,最好不要把 Linux 容器直接暴露到公网上。接着,我们来介绍容器的“限制”。Linux Cgroups 的全称是 Linux Control Group,它最主要的作用是限制一个进程组能够使用的资源上限,包括 CPU、内存、磁盘、网络带宽等等。其中,CPU 子系统能够限制 CPU 的使用率,blkio 用于为磁盘等设备设定 I/O 限制,cpuset 为进程分配单独的 CPU 核和对应的内存节点,memory 为进程设定内存使用的限制。

最后,一个正在运行的 Docker 容器,其实就是一个启用了多个 Linux Namespace 的应用进程,而这个进程能够使用的资源量,则受 Cgroups 配置的限制。可以说,容器就是一个“单进程”模型,在一个容器中,你没办法同时运行两个不同的应用,除非你能事先找到一个公共的 PID=1 的程序来充当两个不同应用的父进程。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容