docker概念-容器运行时、容器、容器镜像及结构

1.什么是容器运行时呢?

容器运行时本质上是负责容器生命周期的核心工具,分为低层运行时(runc) 和高层运行时(containerd)。低层运行时直接调用内核创建隔离环境,高层运行时负责镜像管理、网络等完整功能。容器运行时给容器运行提供了必备的资源。

低层运行时是系统必备的,调整namespace,cgroup资源限制。

高层运行时针对容器的业务特征,进一步进行资源优化,高层运行时建立在底层运行时之上。

2.什么是容器镜像,结构是什么样的

它本质上是一个分层的归档包(常见就是 tar),里面装着容器运行需要的静态文件和元数据。镜像里最核心的东西,就是一个能直接当作容器"根目录"的 root 文件系统:应用代码、依赖库、配置文件都在里面,所以镜像一拉下来,容器就能按同样的环境跑起来。

Docker 镜像之所以高效,是因为它采用了分层机制来构建:每一层都是只读模板,通常对应 Dockerfile 里的一条指令(比如 RUNCOPY)。这样做的好处是层与层之间可以共享复用------多个镜像如果底层一样,就能共用同一批层,下载更快、存储更省、构建也更容易缓存。

按照 OCI 标准,镜像主要包含两块内容:

1)文件系统层(Rootfs):也就是容器看到的"根文件系统视图",和宿主机隔离,容器里的进程只看到自己的那套目录结构。

2)配置元数据(JSON):描述容器启动该怎么跑,比如默认启动命令、环境变量、工作目录、用户权限、安全相关配置等。常见关键文件包括:config.json(运行时配置)、manifest.json(描述层级结构与配置路径)、以及每层对应的 layer.tar(存放实际文件内容)。

总结:容器镜像就是一个按层打包的 root 文件系统 + 一份启动说明书(JSON 配置),让应用在任何机器上都能用一致的环境快速运行。

相关推荐
Shingmc31 小时前
【Linux】线程互斥与同步
linux
Vect__8 小时前
深刻理解进程、线程、程序
linux
w6100104668 小时前
CKAD-2026-Ingress
运维·k8s·ckad
末日汐9 小时前
传输层协议UDP
linux·网络·udp
zzzsde11 小时前
【Linux】库的制作和使用(3)ELF&&动态链接
linux·运维·服务器
CQU_JIAKE11 小时前
4.3【A]
linux·运维·服务器
AI周红伟11 小时前
OpenClaw是什么?OpenClaw能做什么?OpenClaw详细介绍及保姆级部署教程-周红伟
大数据·运维·服务器·人工智能·微信·openclaw
Elastic 中国社区官方博客11 小时前
当 TSDS 遇到 ILM:设计不会拒绝延迟数据的时间序列数据流
大数据·运维·数据库·elasticsearch·搜索引擎·logstash
qing2222222212 小时前
Linux中修改mysql数据表
linux·运维·mysql
Alvin千里无风12 小时前
在 Ubuntu 上从源码安装 Nanobot:轻量级 AI 助手完整指南
linux·人工智能·ubuntu