暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

什么是容器运行时

原创 愤怒的蜗牛 2023-01-06
559

容器运行机制

那么,当你运行 podman run 或 docker run 命令时,在后台到底发生了什么?一个分步的概述如下:

1.    如果本地没有镜像,则从镜像登记仓库(registry)拉取镜像

2.    镜像被提取到一个写时复制(COW)的文件系统上,所有的容器层相互堆叠以形成一个合并的文件系统

3.    为容器准备一个挂载点

4.    从容器镜像中设置元数据,包括诸如覆盖 CMD、来自用户输入的 ENTRYPOINT、设置 SECCOMP 规则等设置,以确保容器按预期运行

5.    提醒内核为该容器分配某种隔离,如进程、网络和文件系统(命名空间(namespace)

6.    提醒内核为改容器分配一些资源限制,如 CPU 或内存限制(控制组(cgroup)

7.    传递一个系统调用(syscall)给内核用于启动容器

8.    设置 SELinux/AppArmor

容器运行时负责上述所有的工作。当我们提及容器运行时,想到的可能是 runc、lxc、containerd、rkt、cri-o 等等。嗯,你没有错。这些都是容器引擎和容器运行时,每一种都是为不同的情况建立的。

容器运行时(Container runtime)更侧重于运行容器,为容器设置命名空间和控制组(cgroup),也被称为底层容器运行时。高层的容器运行时或容器引擎专注于格式、解包、管理和镜像共享。它们还为开发者提供 API。

开放容器计划(OCI)

开放容器计划(Open Container Initiative)(OCI)是一个 Linux 基金会的项目。其目的是设计某些开放标准或围绕如何与容器运行时和容器镜像格式工作的结构。它是由 Docker、rkt、CoreOS 和其他行业领导者于 2015 年 6 月建立的。

它通过两个规范来完成如下任务:

1、镜像规范

该规范的目标是创建可互操作的工具,用于构建、传输和准备运行的容器镜像。

该规范的高层组件包括:

·         镜像清单 — 一个描述构成容器镜像的元素的文件

·         镜像索引 — 镜像清单的注释索引

·         镜像布局 — 一个镜像内容的文件系统布局

·         文件系统布局 — 一个描述容器文件系统的变更集

·         镜像配置 — 确定镜像层顺序和配置的文件,以便转换成 运行时捆包

·         转换 — 解释应该如何进行转换的文件

·         描述符 — 一个描述被引用内容的类型、元数据和内容地址的参考资料

2、运行时规范

该规范用于定义容器的配置、执行环境和生命周期。config.json 文件为所有支持的平台提供了容器配置,并详细定义了用于创建容器的字段。在详细定义执行环境时也描述了为容器的生命周期定义的通用操作,以确保在容器内运行的应用在不同的运行时环境之间有一个一致的环境。

Linux 容器规范使用了各种内核特性,包括命名空间(namespace)控制组(cgroup)权能(capability)、LSM 和文件系统隔离(jail)等来实现该规范。

小结

容器运行时是通过 OCI 规范管理的,以提供一致性和互操作性。许多人在使用容器时不需要了解它们是如何工作的,但当你需要排除故障或优化时,了解容器是一个宝贵的优势。

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论