K8s 为什么要弃用 Docker?_大项目为啥不建议用docker了-程序员宅基地

技术标签: kubernetes  容器  k8s  docker  

在写“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简单易用,工具链完整,界面友好,市面上很难找到与之相媲美的软件。应该说是入门级学习容器技术和云原生的“最佳选择”。

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/agonie201218/article/details/127287323

智能推荐

Linux-Ubuntu c语言程序编译环境设置以及安装Dev-c++编写基于辗转相除法的十进制数转二进制数的C++程序_devc++ linux-程序员宅基地

文章浏览阅读1k次。1.下载VMware虚拟机点击开始下载VMware虚拟机,VMware的版本为17.0.0,需要自行购买或查找对应的激活码。2.下载Ubuntu系统因为Ubuntu官方网站在海外,下载速度极慢,所以推荐选择国内镜像网站以快速下载Ubuntu系统,例如阿里云平台,点击开始下载Ubuntu18.04.6镜像版本。3.VMware虚拟机安装Ubuntu系统根据VMware安装提示可自行完成Ubuntu系统的安装或者自行查找教程,这里便不过多解释。4.Dev-c++的安装进入。_devc++ linux

为myeclipse分配更大的内存_myeclipse扩大内存-程序员宅基地

文章浏览阅读1.4w次,点赞3次,收藏14次。在进行开发大项目时,常常会遇见开发工具卡顿的情况 ,大多数都是因为内存不够的原因造成的,今天学习了为MyEclipse分配更大内存的方法。是通过修改配置文件实现的。一:修改myeclipse.ini文件首先找到MyEclipse的安装目录 打开myeclipse的配置文件 如图选中文件 文档最后三行可以更改数字 根据本机自带物理内存的大小 采用1/4或者1/3适当修改最需要注意的是:在修改完成后_myeclipse扩大内存

java crm 系统 进销存 springmvc SSM项目项目源码-程序员宅基地

文章浏览阅读68次。统介绍:1.系统采用主流的 SSM 框架 jsp JSTL bootstrap html5 (PC浏览器使用)2.springmvc +spring4.3.7+ mybaits3.3 SSM 普通java web(非maven, 附赠pom.xml文件) 数据库:mysql3.开发工具:myeclipse eclipse idea 均可, 没有限制. 我这边myeclipse 2014 导出..._超市进存销库存销售系统源代码ssm javaweb 感兴趣的话点“我想要”和我私聊吧~

php获取蓝凑云文件列表,php调用蓝奏云下载接口-程序员宅基地

文章浏览阅读437次。/*** @package Lanzou* @author Filmy* @version 1.2.1* @link https://mlooc.cn*/header('Access-Control-Allow-Origin:*');header('Content-Type:application/json; charset=utf-8');$url = isset($_GET['url']) ?..._蓝奏云文件详情获取

基于Java+SpringBoot+Vue在线学籍管理系统设计和实现-程序员宅基地

文章浏览阅读2.6k次,点赞24次,收藏26次。对在线学籍管理的流程进行科学整理、归纳和功能的精简,通过软件工程的研究方法,结合当下流行的互联网技术,最终设计并实现了一个简单、易操作的在线学籍管理系统。内容包括系统的设计思路、系统模块和实现方法。系统使用过程主要涉及到管理员、教师和学生三种角色,主要包含系统首页个人中心学生管理教师管理院校管理专业管理班级信息管理课程信息管理学生成绩管理学生学籍管理等功能。系统开发主要在 Windows 系统下进行,采用支持跨平台的java语言开发完成,因此可以运行在任意开发环境下。

xss绕过空格符号_xss的变形--如何绕过xss过滤-程序员宅基地

文章浏览阅读1.1k次。我们可以通过构造xss代码进行各种变形,以绕过xss过滤器的检测1.大小写检测将payload进行大小写转化如click me2.引号的使用不断尝试双引号,单引号,与没有引号如3.用[/]代替空格可以用左斜线来代替空格4.回车在一些位置添加Tab(水平制表符)和回车符,来绕过关键字检测如click me!5.对标签属性值进行转写如字母 ASCII码 十进制编码 十六进制编码a..._xss用/替代空格

随便推点

微信支付服务器请求错误,windows系统下微信支付调用出错 msxml3.dll-程序员宅基地

文章浏览阅读2.6k次。今天来个用户说微信支付功能出现故障。点击时候时候出现服务器故障500。检查步骤:这些先开起来了详细错误提示后出现提示:msxml3.dll问题为了排除是不是msxml3.dll问题我们就把他当作有问题重新注册一次看。运行中执行:regsvr32%windir%\system32\msxml3.dll/s发现没问题注册成功。那问题就不是出在这里了。检查了服务器方面都没有问题。何况同一台服务器上还..._regsvr32 %windir%\system32\msxml3.dll

Java GC的标记-清除算法【总结】_标记清除算法怎么标记的-程序员宅基地

文章浏览阅读3k次。Java GC(Garbage Collector)标记-清除算法:1、标记清除算法:GC标记-清除算法由标记阶段和清除阶段构成,在标记阶段会把所有的活动对象都做上标记,然后在清除阶段会把没有标记的对象,也就是非活动对象回收。名词解释:对象:在GC的世界里对象指的是通过应用程序利用的数据集合,是GC的基本单位。一般由头(header)和域(field)构成。活动对象:能通过引用程序引用的..._标记清除算法怎么标记的

exchange server 2007中的概念_exchange 概念-程序员宅基地

文章浏览阅读898次。 exchange server 2007中的服务器角色概念 通过引入新的服务器角色,已对 Microsoft Exchange Server 2007 的安装和部署进行了重新工程设计,以改进管理体验。Exchange 2007 提供了五种不同的服务器角色,它们分别对应于邮件系统的典型部署和分布方式。“服务器角色”是对在邮件环境中执行特定功能所需的功能和组件进行逻辑分组的单元。每个服务器角_exchange 概念

Google Protocol Buffer 的使用和原理_goole.bpotobuf-程序员宅基地

文章浏览阅读140次。简介什么是 Google Protocol Buffer? 假如您在网上搜索,应该会得到类似这样的文字介绍:Google Protocol Buffer( 简称 Protobuf) 是 Google 公司内部的混合语言数据标准,目前已经正在使用的有超过 48,162 种报文格式定义和超过 12,183 个 .proto 文件。他们用于 RPC 系统和持续数据存储系统。Protocol ..._goole.bpotobuf

C语言统计Byte(即unsigned char型)类型变量中‘1‘的个数_获取unsigned char数组的数量-程序员宅基地

文章浏览阅读1.4k次。昨天,我的计算机网络老师给我们留了一个小作业,统计Byte类型变量中二进制位上1的个数,经过查询,C语言是没有Byte这个类型的,但是等价于unsigned char.代码如下#include<stdio.h> #include<stdlib.h>int count=0;static int CountB(unsigned char b){ int count=0; while(b>0) { if(b%2==1) //此处满足=1说明此二进制位_获取unsigned char数组的数量

nrf52832 学习笔记(六)配对和绑定_nrf52832 qfab使用教程-程序员宅基地

文章浏览阅读5.1k次,点赞6次,收藏32次。nrf52832 学习笔记(六)配对和绑定蓝牙在连接之前都是明文通信的,也就是说主从机之间传输的数据包可以被第三方抓取分析逆向.配对静态密码日常使用蓝牙对从机进行连接时,会提示输入密码,这个其实就是一种配对过程.蓝牙从机中存在一个静态密码.主机连接到从机后,从机启动安全连接认证主机接收到安全连接认证请求后,产生一个随机数,根据随机数和主机的静态密码计算出一个确认值从机同样产生一个随机数,根据随机数和从机的静态密码计算出一个确认值,主从机交换随机数和确认值.主从机通过自己的静态密码和交换来_nrf52832 qfab使用教程

推荐文章

热门文章

相关标签