当前位置: 首页 > news >正文

Docker 两大基石:Namespace 和 Cgroups

🛠️ Docker 两大基石:解密 Namespace 与 Cgroups 的核心魔力

容器技术,尤其是 Docker,已经彻底改变了软件的构建、交付和运行方式。但其背后的魔力究竟是什么?为什么一个简单的进程,就能拥有一个“独立”的操作系统环境,并且不会拖垮整个宿主机?

答案就藏在 Linux 内核提供的两大关键技术中:Namespace(命名空间)Cgroups(控制组)

理解这两点,你就理解了容器的本质。

一、隔离的魔法:Namespace(命名空间)

如果你想让一个应用感觉它独占了整个系统,你需要隔离它的视图。这就是 Namespace 的职责。

Namespace 的核心思想是:将 Linux 系统中的全局资源进行抽象和分区。它为进程创建了一个私有的、独立的资源视图,让容器内的进程只能看到和使用这个私有视图中的资源。

容器本质上就是被 Namespace 隔离和 Cgroups 限制的宿主机进程。

1. Namespace 解决的核心问题:“看到了什么?”

当一个容器启动时,它并不会创建一个虚拟机,它只是在宿主机上启动了一个或多个进程。Namespace 的作用就是欺骗这个进程,让它以为自己是系统上唯一的进程,拥有自己独立的网络、文件系统等。

2. 六大核心 Namespace 类型

Docker 容器的完整隔离性正是通过组合使用以下不同类型的 Namespace 实现的:

Namespace 类型隔离的资源实现的效果
PID进程 ID容器有自己的PID 1(初始化进程)。看不到宿主机上的完整进程列表
NET网络栈容器有自己的网络设备、IP 地址、路由表
MNT文件系统容器有自己的根目录和文件系统结构,通过UnionFS实现高效叠加。
UTS主机名容器可以设置自己的主机名,不影响宿主机和其他容器。
IPC进程间通信隔离 System V IPC 资源,防止容器间干扰。
USER用户和组 ID隔离用户权限。容器内的root用户可以被映射为宿主机上的非特权用户,增强安全性。

通过 Namespace 的隔离,容器获得了独立性安全性,这是容器技术存在的前提。


二、资源的边界:Cgroups(控制组)

光有隔离性还不够。如果一个容器进程意外进入死循环,疯狂占用 CPU 或内存,它仍然会拖垮整个宿主机。这时,就需要有人来扮演“资源管理者”的角色。

这就是 Cgroups(Control Groups)的职责。

1. Cgroups 解决的核心问题:“能用多少?”

Cgroups 允许我们将一组进程组织成一个层级结构,并对这个组及其子组进行资源限制、配额分配和使用情况核算。它确保了资源的公平使用,防止了“资源饥饿”或“资源滥用”。

2. Cgroups 的三大功能:R.A.M.

  • Resource Limiting (资源限制): 限制一个容器最多能使用的资源量(如内存限制)。
  • Accounting (资源核算): 计量一个容器消耗了多少资源(用于监控和计费)。
  • Management (资源分配): 为容器设置资源使用优先级(如 CPU 权重)。

3. 核心 Cgroups 控制器(Subsystems)

Cgroups 通过不同的“控制器”来管理特定的系统资源:

Cgroups 控制器管理的资源实际应用示例
cpuCPU 时间使用--cpu-shares分配相对权重;使用--cpus限制绝对核心数。
memory内存和 SWAP使用-m--memory限制容器可使用的内存上限。
blkio块设备 I/O限制容器对磁盘读写的速率,避免 I/O 密集型容器独占磁盘。
pids进程数量限制容器内可以启动的进程和线程的总数,防止叉炸弹(Fork Bomb)

通过 Cgroups 的资源控制,容器获得了稳定性可靠性,保障了宿主机的稳定运行。


总结:Namespace 与 Cgroups 的完美搭档

Namespace 和 Cgroups 是容器技术不可或缺的一体两面。

特性NamespaceCgroups
目标隔离性资源控制
实现效果虚拟化环境(独立视图)资源边界(限制用量)
类比独立房间的钥匙房间内的水电表

正是 Linux 内核的这两项强大而精巧的机制,共同构建了 Docker 容器的轻量级、高效和安全的运行环境。下一次当你运行docker run命令时,请记住:你正在启动一个进程,而这个进程正在被 Namespace 隔离,并被 Cgroups 约束着,以一种全新的方式运行你的应用程序。

http://www.jsqmd.com/news/79130/

相关文章:

  • 告别排版困境!AI 写作到发布全自动化的完整方案
  • 9、Eclipse集成开发环境:C/C++开发全流程指南
  • 享搭提醒助手:数据变动实时预警,运营者业务状态“尽在掌握”
  • Python银行客户数据流失预测SMOTE平衡数据实现神经网络、SVM、决策树、随机森林与超参数调优|附代码数据
  • 音元系统:绪论
  • 代码随想录算法训练营第三十二天 | 完全背包、518. 零钱兑换 II、377. 组合总和 Ⅳ、卡码网57. 爬楼梯
  • 【题解】CSP-J/S 2025 补题
  • 音元系统:摘要
  • 26 avl树(下)
  • 从“写代码”到“定义问题”——AI 时代程序员的生存宣言
  • 音元系统:目录
  • 最全词典整合收录:打造专业英语学习利器
  • Java毕业设计不会做怎么办?
  • 基于深度学习的文物图像修复系统
  • 零基础理解k8s - 实践
  • Java毕业设计做不出来可以找代做吗?
  • 连接2026:十款远程控制软件真实力横评与选择指南
  • openvela——动态管理日志输出通道及其实现原理
  • JavaScript 引擎中的分支预测器(Branch Predictor)友好性:如何写出减少 CPU 误判的代码
  • Draco 3D压缩终极指南:如何高效处理大型3D模型文件
  • 可以把 Windows 从 C盘迁移到 SSD 吗?
  • Overleaf插件定制实战指南:3分钟搞定编辑器功能优化
  • Day 37 - 早停策略与模型权重的保存
  • 15、Linux 系统下的邮件与即时通讯使用指南
  • JavaScript 的数值计算精度:Kahan 求和算法在处理大量浮点数累加时的应用
  • 为什么 C盘空间会莫名其妙减少(即使没装新软件)?
  • 微信遥控Mac:WeChatPlugin远程控制终极指南
  • 16、探索 Linux:网络应用与文件管理指南
  • 【SOVD】软件定义汽车时代的诊断新范式
  • javet 的使用