容器底层实现技术Namespace/Cgroup

论坛 期权论坛 编程之家     
选择匿名的用户   2021-6-2 20:52   1420   0

Docker容器实现原理

Docker容器在实现上是通过namespace技术来进行进程隔离,通过cgroup技术实现容器进程可用资源的限制,当docker启动一个容器时,实际是创建了多了namespace参数的进程。

图片

图片

Namespace

Namespace:命名空间

作用:资源隔离

原理:namespace将内核的全局资源进行封装,使得每个namespace都有一份独立的资源,因此不同进程在各自namespace内对同一种资源使用不会相互干扰

图片

图片

Cgroups

Cgroups:Linux Control Group

作用:限制一个进程对系统资源的使用上限,包括CPU,内存,Block,I/O等

Cgroups还能设置进程优先级,对进程进行挂起和恢复操作。

原理:将一组进程放在一个Cgroup中,通过给这个Cgroup分配指定的可用资源,达到控制这一组进程可用的目的,

实现:再Linux中,Cgroup以文件和目录的方式组织在操作系统的/sys/fs/cgroup路径下,该路径中所有的资源种类均可被cgroup限制。

图片

CPU资源限制

图片

图片

内存资源限制

图片

容器可以使用的内存资源包括内存这swap资源

BlockIO限制

图片

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:3875789
帖子:775174
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP