当前位置: 首页 > news >正文

企业网站建设费用江西建设部网站

企业网站建设费用,江西建设部网站,大连手机自适应网站建设费用,wordpress后台 登录K8s 为什么要弃用 Docker 最近在学习容器技术的过程中#xff0c;看到有关于Kubernetes“弃用 Docker”的事情#xff0c;担心现在学 Docker 是否还有价值#xff0c;是否现在就应该切换到 containerd 或者是其他 runtime。 随着深入了解#xff0c;这些疑虑的确是有些道理…K8s 为什么要弃用 Docker 最近在学习容器技术的过程中看到有关于Kubernetes“弃用 Docker”的事情担心现在学 Docker 是否还有价值是否现在就应该切换到 containerd 或者是其他 runtime。 随着深入了解这些疑虑的确是有些道理。三年前Kubernetes 放出消息要“弃用 Docker”的时候确确实实在 Kubernetes 社区里掀起了一场“轩然大波”影响甚至波及到社区之外也导致 Kubernetes 不得不写了好几篇博客来反复解释这么做的原因。三年过去了虽然 Kubernetes 1.24 已经达成了“弃用”的目标但对这件事还是没有非常清晰的认识所以记录下这个事件的始末。 背景Kubernetes的发展 要理解 K8s 为何“弃用 Docker”我们得回顾一下 K8s 的发展史。 Kubernetes是Google公司早在2014年就发布开源的一个容器基础设施编排框架这项技术是有理论依据即Borg。Borg是Google公司整个基础设施体系中的一部分Borg是Google公司整个基础设施体系中的一部分Google也发布了多篇关于Borg的论文作为其理论支持。其上承载了比如MapReduce、BigTable等诸多业界的头部技术。因此Borg系统一直以来都被誉为Google公司内部最强大的“秘密武器”也是Google公司最不可能开源的项目而Kubernetes就是在这样的理论基础上开发的。下图是Google Omega论文所描述的Google已公开的基础设施栈。 Kubernetes 项目的架构如下图跟它的原型项目 Borg 非常类似都由 Master 和 Node 两种节点组成而这两种节点分别对应着控制节点和计算节点。 Master 节点也就是控制节点是整个集群的中枢是 Stateful 的负责维持整个 Kubernetes集群的状态。它由三个独立组件组合而成分别是负责 API 服务的 kube-apiserver、负责调度的kube-scheduler以及负责容器编排的 kube-controller-manager。整个集群的持久化数据则由kube-api-server 处理后保存在 Etcd 中。为了保证职责单一Master 节点一般不会部署容器。 Borg 对 Kubernetes 的指导体现在 Master 节点上Borg 和 Kubernetes 的 Master 节点虽然实现细节上可能会不同但它们出发的高度却是一致的即如何编排、管理、调度用户提交的作业。 Node 节点也就是计算节点它才是部署的容器真正运行的地方。它上面最核心的是 kubelet 组件master 节点上也会有 kubelet 组件Kubelet 主要负责同容器运行时比如 Docker 项目打交道使用了 CRIContainer Runtime Interface的远程调用接口。这个接口定义了容器运行时的各项核心操作比如启动一个容器需要的所有参数。这也是为什么 Kubernetes 项目并不关心你使用的是什么容器运行时只要这个容器运行时能够运行标准的容器镜像它就可以通过实现 CRI 接入到 Kubernetes 项目当中。 具体的容器运行时比如 Docker 项目则一般通过 OCI 这个容器运行时规范同底层的 Linux 操作系统进行交互即把 CRI 请求翻译成对 Linux 操作系统的调用比如调用 Namespace 和 Cgroups 等。 此外kubelet 还通过 gRPC 协议与 Device Plugin 进行交互这个插件是 Kubernetes 用来管理 GPU 等宿主机物理设备的主要组件也是基于 Kubernetes 项目进行机器学习训练、高性能作业支持等工作必须关注的功能。 kubelet 还可以通过 CNIContainer Networking Interface和 CSIContainer Storage Interface接口分别调用网络插件和存储插件为容器配置网络和持久化存储。 kubelet 这个名字来自于 Borg 项目中的同源组件 Borglet。只是Borg 项目中并不支持容器技术而只是简单地使用了 Linux Cgroups 对进程进行限制。这也就意味着像 Docker 这样的“容器镜像”在 Borg 中并不存在自然不需要对容器镜像进行管理但是 Google 内部却有在使用一个包管理工具名叫 Midas Package ManagerMPM,它可以部分取代 Docker 镜像的角色。之外Borglet 组件也不需要考虑如何同 Docker 进行交互也不需要支持 CRI、CNI、CSI 等诸多容器技术接口。可以说 kubelet 完全就是为了实现 Kubernetes 对容器的管理能力而重新实现的一个组件与 Borg 之间并没有直接的传承关系。 Kubernetes 项目并没有像同时期的各种“容器云”项目那样把 Docker 作为整个架构的核心而仅仅把它作为最底层的一个容器运行时实现。也就相当于把 Docker 仅仅看成一种新的应用打包方式那么 Borg 过去在大规模作业管理与编排上的经验就可以直接应用到 Kubernetes 项目上。 CRI 而在2014 年Docker 正处于鼎盛时期K8s 刚刚诞生虽然它得到了 Google 和 Borg 的支持但它还是比较新的。 因此K8s 首先选择支持 Docker 。 快进到 2016 年CNCF 成立一年K8s 也发布了 1.0 版本可以正式用于生产环境。这些都表明 K8s 已经长大了。 于是宣布加入 CNCF成为第一个 CNCF 托管项目。它想利用基金会的力量联合其他厂商来“打倒”Docker。 在 2016 年底的 1.5 版本中K8s 引入了新的接口标准CRIContainer 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 部分捐赠给 CNCFcontainerd 形成。 作为 CNCF 的托管项目containerd 必须符合 CRI 标准。但是由于很多原因Docker 只是 containerd 在 Docker Engine 中调用对外的接口保持不变也就是说不兼容 CRI。 由于 Docker 的“固执”此时 K8s 中有两条调用链 使用 CRI 接口调用 dockershim然后 dockershim 调用 DockerDocker 再去 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.03containerd1.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 InitiativeDocker镜像在K8s中仍然可以正常使用不需要改变原有的开发测试和CI/CD流程。我们仍然可以拉取 Docker Hub或者编写一个 Dockerfile 来打包应用程序。 其次Docker是一个完整的软件产品线不仅仅是containerd它还包括镜像构建、分发、测试等很多服务甚至连K8s都内置于Docker Desktop中。 就容器开发的便利性而言Docker暂时还难以被取代。大多数云原生开发人员可以继续在这个熟悉的环境中工作使用Docker来开发在K8s中运行的应用程序。 同样虽然 K8s 不再包含dockershimDocker 已经接管了这部分代码并构建了一个名为cri-dockerd的项目该项目也同样工作将 Docker Engine 适配为 CRI 接口这样就kubelet可以通过它再次操作Docker就好像它从来没有发生过一样。 总的来说Docker虽然在容器编排大战中败下阵来被K8s挤到了墙角但依然具有很强的生命力。多年积累的众多忠实用户和大量应用形象是其最大的资本和后盾。足以支持它在另一条不与 K8s 正面交锋的道路上。 对于初学者来说Docker简单易用工具链完整界面友好市面上很难找到与之相媲美的软件。应该说是入门级学习容器技术和云原生的“最佳选择”。 参考 【K8s 为什么要弃用 Docker】https://mp.weixin.qq.com/s/qEKyEseD370xWI-2yIyUzg 【Docker与k8s的恩怨情仇】https://www.cnblogs.com/powertoolsteam/p/14980851.html 【k8s为什么会抛弃docker】https://boilingfrog.github.io/2023/01/07/k8s为什么会抛弃docker/ 今天的分享就到此结束了 欢迎点赞评论互关三连
http://icebutterfly214.com/news/34823/

相关文章:

  • OpenEuler 22.03 安装zabbix-agent(源代码编译及自制rpm包)
  • 部署MQTT Broker - Mosquitto - -YADA
  • Vue实例学习
  • 【数据结构】第六章启航:图论入门——从零掌握有向图、无向图与简单图
  • 2025大桶/桶装/纯净/瓶装/灌装水设备推荐榜:青州市路得自动化五星领跑 四大品牌赋能水企高效生产
  • 专题:2025AI时代的医疗保健业:应用与行业趋势研究报告|附130+份报告PDF、数据、可视化模板汇总下载
  • 团队作业2——需求规格说明书
  • 2025/11/14
  • Machine Learning - SVM Part 2: The Radial Kernel
  • 焊接工业机器人节气装置
  • 【chrome】chrome浏览器OptGuideOnDeviceModel模型占用磁盘空间的解决方法!
  • QCombox判断是否包含某项
  • 植物大战僵尸2下载教程:延续经典塔防,体验全新时空冒险
  • JavaWeb05-Web基础
  • Git分支合并
  • 多智能体设计模式和智能体框架,你会了么?
  • 新手入门常用的Dos命令
  • 基于MATLAB的B样条曲面绘制
  • 补题若干(5)
  • Go Web 编程快速入门 02 - 认识 net/http 与 Handler 接口 - 实践
  • 2025年热浸锌桥架厂家权威推荐榜单:不锈钢桥架/光伏锌铝镁桥架/喷塑桥架源头厂家精选
  • 鲜花:m 群 bot 随机一言摘抄
  • Tita 项目管理软件:驱动互联网企业高效运营与战略落地新引擎
  • 2025年现代风格卫生间隔断生产厂家权威推荐榜单:易清洁卫生间隔断/欧式卫生间隔断/养老院卫生间隔断源头厂家精选
  • locust基础
  • 荆门定制西林瓶灌装机费用解析,比标准款贵多少?
  • 基于Ubuntu2504部署OpenStack E版
  • 常见的无状态服务与典型有状态服务
  • 【IEEE出版 | 连续4年稳定EI检索】第五届新能源与电力工程国际学术会议(ICNEPE 2025)
  • 5分钟极简代码:轻松学会XXTEA加密解密