欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 编程资源 > 编程问答 >内容正文

编程问答

容器底层实现技术Namespace/Cgroup

发布时间:2025/3/8 编程问答 46 豆豆
生活随笔 收集整理的这篇文章主要介绍了 容器底层实现技术Namespace/Cgroup 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

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限制

 

总结

以上是生活随笔为你收集整理的容器底层实现技术Namespace/Cgroup的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。