Docker、containerd的关系

Docker、containerd的关系

containerd囊括了单机运行一个容器时所需要的一切:
为了能够支持多种OCI Runtimecontainerd 内部使用containerd-shim,每启动一个容器都会创建一个新的containerd-shim进程,指定容器ID,Bundle目录,运行时的二进制(比如runc)

1、docker

docker本身而言,包括docker clientdockerd,是一个客户端工具,用来把用户的请求发送给docker daemon(dockerd)
dockerddockerd是对容器相关操作的最上层封装,直接面向操作用户。Docker daemon,一般也会被称为docker enginedockerd启动时会启动containerd 子进程。

2、containerd

containerd是一个工业级别标准的容器运行时,它强调简单性、健壮性和可移植性,几乎囊括了单机运行一个容器运行时所需要的一切:执行、分发、监控、网络、构建、日志等。主要作用是:

  • 1)、管理容器的生命周期(从创建容器到销毁容器)
  • 2)、拉取/推送容器镜像
  • 3)、存储管理(管理镜像及容器数据的存储)
  • 4)、调用runC运行容器(与runC等容器运行时交互)
  • 5)、管理容器网络接口及网络
    dockerd实际真实调用的还是containerd的api接口,containerddockerdrunC之间的一个中间交流组件。

3、containerd-shim

containerd-shim是一个真实运行容器的载体,为了能够支持多种OCI Runtimecontainerd内部使用containerd-shim,每启动一个容器都会起一个新的containerd-shim的进程。它通常指定三个因素:容器ID、bundle目录(对应某个容器生成的目录,一般位于:/var/run/docker/containerd/containerID)

4、runC

runC是一个轻量级的工具,用来运行容器的,我们可以不用通过docker引擎,直接运行容器。

总的来说docker镜像containerd镜像通用,但组织方式和存放目录不同,导致docker与ctr命令不通用,各自管理自己的镜像和容器。此外k8s还有客户端命令crictl,用法与docker基本相同,可crictl -h查看用法。

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

河越柯衍

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值