k8s为什么要弃用docker?

云原生技术社区 云原生技术社区     2023-04-15     310

关键词:

在写“K8s”系列文章的过程中,很多读者留言询问 K8s 弃用 Docker 的事,担心现在学习 Docker 是否还值得,是不是该切换到 containerd 或其他运行时。

这些怀疑有一定的道理。两年前,K8s 发布“弃用 Docker”的消息时,确实在社区引起了“轩然大波”,影响甚至蔓延到了社区之外,K8s 不得不写了好几篇博客来重复解释原因。

两年过去了,虽然 K8s 1.24 已经实现了“弃用 Docker”的目标,但很多人似乎对这一点还不是很清楚。所以本篇文章就来聊聊这个话题。

CRI(容器运行时接口)

要理解 K8s 为何“弃用 Docker”,我们得回顾一下 K8s 的发展史。

2014 年,Docker 正处于鼎盛时期,而 K8s 刚刚诞生。虽然它得到了 Google 和 Borg 的支持,但它还是比较新的。

因此,K8s 首先选择支持 Docker 。

快进到 2016 年,CNCF 成立一年,K8s 也发布了 1.0 版本,可以正式用于生产环境。这些都表明 K8s 已经长大了。

于是宣布加入 CNCF,成为第一个 CNCF 托管项目。它想利用基金会的力量联合其他厂商来“打倒”Docker。

在 2016 年底的 1.5 版本中,K8s 引入了新的接口标准:CRI:Container Runtime Interface 容器运行时接口。

CRI 使用ProtoBufferandgPRC来指定kubelet应该如何调用容器运行时来管理容器和镜像,但这是一组与以前的 Docker 调用完全不兼容的新接口。

显然它不想再和 Docker 绑定,在底层允许访问其他容器技术(如 rkt、kata 等),可以随时“踢开” Docker。

但此时 Docker 已经非常成熟,市场的惯性也非常强。各大云厂商不可能一下子全部替换掉 Docker。

因此,K8s 只能同时提供一种“折中”的方案,在kubelet和 Docker 之间增加一个“适配器”,将 Docker 的接口转换为 CRI 兼容的接口:

因为这个“适配器”夹在kubeletDocker 和 Docker 之间,所以形象地称为“shim”,意思是“垫片”。

有了 CRI 和 shim,虽然 K8s 仍然使用 Docker 作为底层运行时,但它也具备了与 Docker 解耦的条件,从而拉开了“弃用 Docker”大戏的帷幕。

Containerd

面对挑战,Docker 采取了“断臂求生”的策略,推动自身重构,将原有单一架构的 Docker Engine 拆分成多个模块,其中 Docker daemon 部分捐赠给 CNCF,containerd 形成。

作为 CNCF 的托管项目,containerd 必须符合 CRI 标准。但是由于很多原因,Docker 只是 containerd 在 Docker Engine 中调用,对外的接口保持不变,也就是说不兼容 CRI。

由于 Docker 的“固执”,此时 K8s 中有两条调用链:

  • 使用 CRI 接口调用 dockershim,然后 dockershim 调用 Docker,Docker 再去 containerd 操作容器。

  • 使用 CRI 接口直接调用 containerd 操作容器。

显然,因为 containerd 是用来管理容器的,所以这两个调用链的最终效果是完全一样的,但是第二种方法去掉了 dockershim 和 Docker Engine 这两个环节,更加简洁明了,性能也更好。

2018 年 Kubernetes 1.10 发布时,containerd 也更新到 1.1 版本,正式与 Kubernetes 集成,并发表[博文](https://kubernetes.io/blog/2018/05/24/kubernetes-containerd-integration- gos-ga/ "博文")显示一些性能测试数据:

从这些数据可以看出,相比当时的 Docker 18.03,containerd1.1Pod 启动延迟降低了 20% 左右,CPU 使用率降低了 68%,内存使用率降低了 12%,这样可观的性能提升对云厂商来说是非常有诱惑力的。

弃用Docker

2020 年,K8s 1.20 终于正式向 Docker “宣战”:kubelet将弃用 Docker 支持,并将在未来的版本中完全移除。

但由于 Docker 几乎已经成为容器技术的代名词,而且 K8s 已经使用 Docker 多年,该公告在传播时很快“变味了”,“kubelet 将弃用 Docker 支持”被简化为更吸人眼球的东西 “K8s 将弃用”Docker”。

这自然引起了 IT 界的恐慌,“不明真相的群众”纷纷表示震惊:

用了这么久的 Docker 突然不能用了。

为什么 K8s 会这样对待 Docker?

之前对 Docker 的投资会归零吗?现有的大量镜像怎么办?

其实,如果你了解了上面提到的这两个项目CRIcontainerd你就会知道,K8s 的这一举动并不奇怪,一切都是“自然”的:其实只是“弃用 dockershim ”,也就是dockershim搬出kubelet并不是“弃用 Docker”的软件产品

因此,“弃用 Docker”对 K8s 和 Docker 的影响不大,因为它们都已经将底层改为开源containerd,原有的 Docker 镜像和容器仍然可以正常运行。唯一的变化是K8s绕过了Docker,直接调用Docker内部的containerd

然而,还是会有一些影响。如果K8s直接使用containerd来操作容器,那么它就是一个独立于Docker的工作环境,两者都无法访问对方管理的容器和镜像。换句话说,使用docker ps命令将不会看到K8s中运行的容器。

这对一些人来说可能需要花一点时间来适应并使用新工具crictl,但用于查看容器和镜像的子命令仍然是相同的,例如ps,images等,不难适应(如果你一直在用kubectl管理K8s,这个没有影响)。

K8s 原本计划用一年时间完成“弃用 Docker”的工作,但它确实低估了 Docker 的基础。1.23版本还是没能移除dockershim,只好延期半年。最后,1.24版本从 kubelet 中删除了dockershim的代码。

从此,Kubernetes 与 Docker 彻底“分道扬镳”。

Docker 的未来

那么,Docker 的未来会怎样呢?云原生时代就没有它的立足之地吗?这个问题的答案显然是否定的。

作为容器技术的奠基人,没有人可以质疑 Docker 的历史地位。虽然 K8s 默认不再绑定 Docker,但 Docker 仍然可以以其他形式的 K8s 共存。

首先,由于容器镜像格式已经标准化(OCI规范,Open Container Initiative),Docker镜像在K8s中仍然可以正常使用,不需要改变原有的开发测试和CI/CD流程。我们仍然可以拉取 Docker Hub,或者编写一个 Dockerfile 来打包应用程序。

其次,Docker是一个完整的软件产品线,不仅仅是containerd,它还包括镜像构建、分发、测试等很多服务,甚至连K8s都内置于Docker Desktop中。

就容器开发的便利性而言,Docker暂时还难以被取代。大多数云原生开发人员可以继续在这个熟悉的环境中工作,使用Docker来开发在K8s中运行的应用程序。

同样,虽然 K8s 不再包含dockershim,Docker 已经接管了这部分代码并构建了一个名为cri-dockerd的项目,该项目也同样工作,将 Docker Engine 适配为 CRI 接口,这样就kubelet可以通过它再次操作Docker,就好像它从来没有发生过一样。

总的来说,Docker虽然在容器编排大战中败下阵来,被K8s挤到了墙角,但依然具有很强的生命力。多年积累的众多忠实用户和大量应用形象是其最大的资本和后盾。足以支持它在另一条不与 K8s 正面交锋的道路上。

对于初学者来说,Docker简单易用,工具链完整,界面友好,市面上很难找到与之相媲美的软件。应该说是入门级学习容器技术和云原生的“最佳选择”。

本文译自:K8s — Why Deprecating Docker?[1] 作者:Tony

云原生技术社区有20+技术交流群,想进群跟技术大牛们聊天,或加入志愿者队伍,请加小助手微信:

引用链接

[1]

K8s — Why Deprecating Docker?: https://medium.com/nerd-for-tech/k8s-why-deprecating-docker-5d1eccde0775"

本文由 mdnice 多平台发布

替代要弃用的 UIView 自动布局方法

】替代要弃用的UIView自动布局方法【英文标题】:AlternativetoUIViewautolayoutmethodswhicharetobedeprecated【发布时间】:2015-04-2806:03:45【问题描述】:根据UIView.h头文件,下面的方法将被弃用。在代码中使用自动布局的替代方法是什么?我... 查看详情

k8s1.20弃用docker评估之docker和oci镜像格式的差别(代码片段)

...构建容器镜像,并且可以继续在containerd和CRI-O上使用。那为什么发现Docker镜像和Containerd镜像存在不兼容情况?具体如下:在K8S>1.20版本中,发现containerdctr上传到镜像仓库的镜像与同版本的docker镜像间存在以下问题不能被docker... 查看详情

k8s弃用docker了?docker不能用了?别逗了!(代码片段)

Docker大概没想到,2020年,它在技术圈内的两次成为(舆论的)焦点,竟然都是因为信息差(说是“标题党”也不为过)。概览2013年Docker是在2013年的PyCon上首次正式对外公布的。它带来了一种先进的软件交付方式,即,通过容器... 查看详情

docker不香吗?为什么还要用k8s

本文禁止转载!目录容器化时代来了容器化技术的尖刀武器Docker横空出世Docker怎么用?编排系统的需求催生k8sk8s与DockerSwarm江湖恩怨k8s是做什么用的?K8s架构和组件Docker与k8s难舍难分开发实践,灵魂追问最后一个... 查看详情

docker不香吗?为什么还要用k8s

本文禁止转载!目录容器化时代来了容器化技术的尖刀武器Docker横空出世Docker怎么用?编排系统的需求催生k8sk8s与DockerSwarm江湖恩怨k8s是做什么用的?K8s架构和组件Docker与k8s难舍难分开发实践,灵魂追问最后一个... 查看详情

docker和k8s面试总结

...面试题如下每一点可根据回答进行适当深入2.1什么是k8s?1为什么用k8s解决了什么问题?2k8s有哪些组件,有什么作用?【同:Master节点和Node节点都用哪些组件】3可以简单说下NodePodcontainer之间的关系吗?【可引入2.2/2.3对PodSVC的考察... 查看详情

docker和k8s的概念-iaaspaassaas的区别

docker和k8s参考:什么是Docker?Kubernetes概述openstack,docker,mesos,k8s什么关系?IaaS、PaaS、SaaS的概念SaaS:软件服务,Software-as-a-servicePaaS:平台服务,Platform-as-a-serviceIaaS:基础设施服务,Infrastructure-as-a-serviceIaaSIaaS是云服务的最底层 查看详情

docker与k8s概念简述(代码片段)

Docker与K8s概念八股文Docker常规题K8s简答题1、简述etcd及其特点?2、简述etcd适应的场景?3、简述什么是Kubernetes?4、简述Kubernetes如何实现集群管理?5、简述Kubernetes的优势、适用场景及其特点?6、简述K8s相关基... 查看详情

docker与k8s的恩怨情仇—成为paas前浪的cloudfoundry

...容器化背后的原理到底是什么吗?容器化技术满天下,那为什么只有Docker被大家所熟知呢?后Docker时代,到底谁才是云原生时代的王者?我们相信本系列文章能帮您解答这些疑惑。被“嫌弃”的物理服务器在云时代以前,开发者... 查看详情

kunernetes-k8s架构的安装与使用(详细)(代码片段)

文章目录一、kunernetes简介1.为什么要用k8s?2.部署方式的变迁3.传统部署时代4.虚拟化部署时代5.容器部署时代6.服务器费用对比7.k8s是什么?8.纯容器模式的问题9.为什么要用k8s10.k8s提供了什么功能二、k8s架构安装1.k8s流程2.k8s工作原... 查看详情

docker与k8s概念简述(代码片段)

Docker与K8s概念八股文Docker常规题K8s简答题1、简述etcd及其特点?2、简述etcd适应的场景?3、简述什么是Kubernetes?4、简述Kubernetes如何实现集群管理?5、简述Kubernetes的优势、适用场景及其特点?6、简述K8s相关基... 查看详情

细说kubernetes-为啥是pod?

...之后也就渐渐的接受了pod这个东西,但是你有没有想过,为什么是pod?k8s为什么会有这样的设计?今天我们就来细细说说这个pod首先我们来回忆看看k8s的架构图是什么样子的从架构图中我们可以看到,整个k8s的设计架构有以下几... 查看详情

云原生是趋势吗?学习k8s和docker的意义在哪里?

...机”有什么区别?请看云原生入门技能树。细细说下为什么。从前,写代码只要在单机上写即可,但是编程会演化。例如,写单机程序。写一个单 查看详情

系统学习docker---第一节:docker前言知识

为什么回过头来看docker呢?因为学k8s的时候太吃劲了,一个月,每天早上弄一点,基本上才安装了一个环境,而且,还不一定好用.越到后面越费劲,很多东西都断片.后来才知道,是因为基础知识不扎实.so.....哪里不行补哪里,在回过头来看... 查看详情

docker&k8s---通过kubeadm快速部署k8s

文章目录Docker&K8s---通过kubeadm快速部署K8s环境准备环境初始化开始安装安装docker添加kubernetes的yum软件源安装kubeadm,kubelet和kubectl部署KubernetesMaster节点加入集群安装网络插件测试Kubernetes集群在从节点上也可以使用kubectl其他错误... 查看详情

docker&k8s---通过kubeadm快速部署k8s(代码片段)

文章目录Docker&K8s---通过kubeadm快速部署K8s环境准备环境初始化开始安装安装docker添加kubernetes的yum软件源安装kubeadm,kubelet和kubectl部署KubernetesMaster节点加入集群安装网络插件测试Kubernetes集群在从节点上也可以使用kubectl其他错误... 查看详情

k8s+docker(学习.....)

docker安装(基于linux)一、docker的官方安装文档:https://docs.docker.com/engine/installation/linux/centos/由docker给的文档可以看出它也只是去配置了一个docker的yum源、然后就通过这个源来安装docker了;在这个文档下我们采用手工配置的方式... 查看详情

azuredevops上模版化k8s部署

...程。 前提条件本文不讨论K8s是什么,什么是容器化,为什么需要容器化,什么是微服务等这些基础内容,这些到处说的烂大街了。此类内容有兴趣可以看看微软系的介绍:微服务体系架构设计微服务体系结构本文假设你已经... 查看详情