Docker容器实现原理
Docker容器在实现上是通过namespace技术来进行进程隔离,通过cgroup技术实现容器进程可用资源的限制,当docker启动一个容器时,实际是创建了多了namespace参数的进程。
data:image/s3,"s3://crabby-images/6a490/6a49024f01b1f04dbd7bd09b73df6a3de92f1a81" alt="图片"
data:image/s3,"s3://crabby-images/ad8a2/ad8a2f9e11f3990591004d1c1ad375440e003998" alt="图片"
Namespace
Namespace:命名空间
作用:资源隔离
原理:namespace将内核的全局资源进行封装,使得每个namespace都有一份独立的资源,因此不同进程在各自namespace内对同一种资源使用不会相互干扰
data:image/s3,"s3://crabby-images/ebb83/ebb83d0d4ef451108a6d0d41f30eeb1b7bd64d67" alt="图片"
data:image/s3,"s3://crabby-images/13aab/13aab0c6e8d8f355acdfcb0192b3d10768dcfd7d" alt="图片"
Cgroups
Cgroups:Linux Control Group
作用:限制一个进程对系统资源的使用上限,包括CPU,内存,Block,I/O等
Cgroups还能设置进程优先级,对进程进行挂起和恢复操作。
原理:将一组进程放在一个Cgroup中,通过给这个Cgroup分配指定的可用资源,达到控制这一组进程可用的目的,
实现:再Linux中,Cgroup以文件和目录的方式组织在操作系统的/sys/fs/cgroup路径下,该路径中所有的资源种类均可被cgroup限制。
data:image/s3,"s3://crabby-images/218e3/218e3833f6dbc795fa9bab637940d4970f43888c" alt="图片"
CPU资源限制
data:image/s3,"s3://crabby-images/65131/651318f4c91448c49ca66f6f026b2df404de3d8e" alt="图片"
data:image/s3,"s3://crabby-images/e56be/e56be8ec4272589254ee71837c15d3d753fac36e" alt="图片"
内存资源限制
data:image/s3,"s3://crabby-images/74895/7489596ce0ddf20ab516dba3c74a9ea733d7a33d" alt="图片"
容器可以使用的内存资源包括内存这swap资源
BlockIO限制
data:image/s3,"s3://crabby-images/e8ddc/e8ddcb8dc2c1f34a6b8af32eee25ef97c2da437c" alt="图片"
|