Docker组件架构

介绍docker架构中的常见组成部分

Posted by Cheney.Yin on January 17, 2022

Docker组件架构

总概

组件类别 组件 介绍
docker相关组件 docker docker客户端,负责发送docker操作请求。
同上 dockerd docker服务入口,负责接受客户端请求并返回请求结果。
同上 docker-init 当业务主进程没有回收能力时,docker-init可以作为容器的1号进程,负责管理容器内的子进程。
同上 docker-proxy docker的网络实现,通过设置iptables规则使得访问主机的流量可以发送至容器内。
containerd相关 containerd 负责管理容器的生命周期, 通过接收dockerd的请求,执行启动或者销毁容器。
同上 contianerd-shim 将containerd和真正的容器进程解耦。使用containerd-shim作为容器的父进程,可以实现重启containerd而不影响已经启动的容器进程。
同上 ctr containerd的客户端, 可以向containerd发送容器请求,主要用来调试开发。
容器运行时组件 runc 命令行工具,通过调用namespacecgroup等系统接口,实现容器的创建和销毁。

图1 docker组建架构