Dockershim 与 Containerd:两种容器运行时的故事

在不断发展的容器化世界中,两个关键组件经常被混淆:Dockershim 和 containerd。虽然它们在管理容器方面都发挥着重要作用,但它们的用途却截然不同。本文深入探讨了它们的功能,深入探讨了 Dockershim 和 containerd 之间的区别。

揭秘 Dockershim:Docker Orchestrator Bridge

Dockershim 是 Docker 运行时垫片的缩写,是 Kubernetes 容器编排平台中的一个特定组件。它的主要功能是充当 Kubernetes 和 Docker 之间的桥梁。以下是 Dockershim 角色的细分:

  • Kubernetes 通信: Kubernetes 使用容器运行时接口 (CRI) 与容器运行时进行交互。Dockershim 将 Kubernetes 的 CRI 请求转换为容器引擎 Docker 能够理解的命令。

  • Docker 引擎集成: Dockershim 依赖 Docker 引擎的功能来管理容器生命周期(创建、启动、停止、删除)。它本质上充当 Kubernetes 的转换器,以利用 Docker 的功能。

Dockershim 的缺点:

虽然 Dockershim 最初达到了其目的,但它也有局限性:

  • 供应商锁定:它将 Kubernetes 与 Docker 绑定在一起,阻碍了使用替代容器运行时(例如 containerd 或 CRI-O)。

  • 功能有限: Dockershim 仅提供了像 containerd 这样的成熟容器运行时所提供的部分功能。

进入 containerd:通用容器运行时

另一方面,Containerd 是一个轻量级容器运行时,它为管理容器镜像、进程和存储提供了底层基础。它拥有几个关键功能:

  • 供应商无关:与 Dockershim 不同,containerd 的设计与容器编排平台或容器引擎无关。它实现了 CRI,允许各种编排器(如 Kubernetes)直接与其交互。

  • 丰富的功能:与 Dockershim 相比,Containerd 提供的功能更加丰富,包括镜像管理、进程监控、检查点和沙盒功能。

  • 独立运行: Containerd 可以独立于 Docker 或任何其他容器引擎运行。它提供模块化方法,允许用户选择最适合其需求的镜像管理工具。

containerd的崛起:

Containerd 的灵活性和功能使其成为寻求摆脱供应商锁定的容器编排平台的自然选择。结果:

  • Kubernetes 和 containerd: Kubernetes 已从 Dockershim 转型,使 containerd 成为大多数部署的默认容器运行时。

  • Docker 拥抱 containerd:有趣的是,Docker 本身现在在底层利用 containerd,利用其功能进行自己的容器管理。

Dockershim 与 containerd:正面比较

16671ac101dc22fe4125f99358cc4c95.png

结论:Dockershim 的基础和 containerd 的未来

虽然 Dockershim 在 Kubernetes 早期发挥了重要作用,但 containerd 的灵活性和功能集使其成为容器编排平台的首选。随着容器化的不断发展,containerd 将继续成为一项基石技术,为管理容器化应用程序提供强大且与供应商无关的基础。

推荐

A Big Picture of Kubernetes

Kubernetes入门培训(内含PPT)


原创不易,随手关注或者”在看“,诚挚感谢!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/684277.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

亚马逊运营黑科技,自养号测评技术打造产品权重

关于亚马逊运营,常规运营投入的成本过于高,而且广告投入效果也微乎其微,这也是为什么大多数卖家选择自养号测评的最主要原因。自养号测评技术,是一种用于提升产品权重和知名度的策略。以下是对该技术的详细解析: 一、…

CSS 常用的三种居中定位布局

嗨,我是小路。今天主要和大家分享的主题是“”。 一、三种常用布局 1.子绝父相 margin 居中 注意:父级相对定位,子级绝对定位,并且子级margin-left,margin-top是负值,为宽度、高度的一半。 /** …

Java 中的 Map 集合:入门篇

在 Java 编程中,Map 是用于存储键值对。它提供了快速的查找和检索功能,是处理大量数据的理想选择。 本文将深入介绍 Java 中的 Map 集合,包括其基本概念、常见实现类、典型用法以及一些常见问题的解决方案。 1. Map 的基本概念 Map 是一种键…

电脑响度均衡是什么?它如何开启?

什么是响度均衡 响度均衡(Loudness Equalization)是一种音频处理技术,旨在平衡音频信号的响度水平,使得不同音源在播放时具有相似的响度感受。简单来说,它可以让用户在播放不同音轨或音频内容时,不需要频繁…

Echarts柱状图数据太多,自定义长度之后,自适应浏览器缩放

不知道是不是最优解,但是当前解决了我遇到的问题,如有更好的方法,希望看到这篇文章的同学可以不吝指导一番,非常感谢 1、问题描述: 因Ecahrts柱状图数据有时多有时少,所以在数据达到一定程度之后&#xff…

20240606在Toybrick的TB-RK3588开发板的Android12下确认HDMI的驱动

20240606在Toybrick的TB-RK3588开发板的Android12下确认HDMI的驱动 2024/6/6 9:48 【原文是在RK3328的Android7.1下写的。我将它升级成为RK3588的Android12了】 RK平台主要采用 FB 和 DRM 两种显示框架。与此相对应, HDMI 也有两套驱动。 FB: LINUX 3.10…

分表策略,你真的分对了?

垂直分表方案 表的记录并不多,但是字段却很长,表占用空间很大,检索表的时候需要执行大量的IO,严重降低了性能。这时需要把大的字段拆分到另一个表,并且该表与原表是一对一的关系。 为什么垂直拆分之后查询性能就变快…

Django里的Form组件

Form组件提供 自动生成HTML标签和半自动读取关联数据 (“半自动”是指还得需要自己手写输入数据进来)表单验证和错误提示 要想创建并使用该组件,操作步骤如下: 在 views.py 里创建类 # 在 views.py 文件里from django import formsclass AssetForm(fo…

HDFS文件块损坏处理方案

1、问题概述 flume采集文本文件存储到hdfs中hive的ods层目录,并在hive中通过msck repair table刷新元数据,加载文本文件。报错如下: 2、问题分析 文件块BP-531411289-172.31.57.12-1539657748238出现了未知异常,导致namenode不能获取该文件块的信息,该文件块是由flume采…

JeecgBoot/SpringBoot升级Nacos(2.0.4到2.2.3)启动报错

错误如下&#xff1a; 报这种错误基本就很头大了&#xff0c;是框架不兼容的问题&#xff0c;自己找很难找到解决方法。 解决方案是把SpringBoot框架版本调高。 修改前&#xff1a; <parent><groupId>org.springframework.boot</groupId><artifactId&g…

如何在 Mac 上玩 Windows 游戏:Parallels Desktop 玩转秘籍

引言 作为一名热爱游戏的 Mac 用户&#xff0c;你可能曾为 Mac 系统的有限游戏选择感到困扰。然而&#xff0c;通过 Parallels Desktop 虚拟机软件&#xff0c;你可以在 Mac 上轻松畅玩多款 Windows 游戏&#xff0c;尽情体验游戏的乐趣。 为什么选择 Parallels Desktop&…

刷机维修进阶教程-----魅族18系列 魅族21系列机型修复基带 改写参数等 通用新机型操作 步骤解析

在前面几期博文中解析了一些老款机型修复基带 修复各项参数以及改写参数的步骤解析。通常这些步骤可以用于各种问题导致的基带丢失 串码丢失以及有些参数修复或者一些特殊场合需要改写参数的需求。今天对于一些新机型操作以上需求做一些步骤解析,明白其操作原理。可以通用于一…

LeetCode 26删除有序数组中的重复项

去重题&#xff0c;双指针&#xff0c;&#xff0c;因为题干说原地删除&#xff0c;且nums其余元素不重要。一个cur记录当前不重复的数应该插在第几位了&#xff0c;for循环里的i相当于是第二个指针&#xff08;右指针&#xff09;&#xff0c;遍历数组来找不重复的元素 class …

C#WPF数字大屏项目实战12--动态获取设备数据

1、如何获取设备实时数据 现在大屏上的数据都是静态的数据或后台构造的来源数据&#xff0c;在实际项目中现场数据应该来自现场的实时数据&#xff0c;这些数据有些是来自现场设备的动态数据&#xff0c;有些是来自其他系统推送的&#xff0c;有些需要主动查询其他业务&#xf…

基于Arduino的简易磁悬浮装置原理图和源代码分享

磁悬浮装置原理 大家可能都玩过这种磁悬浮玩具&#xff0c;它们的工作原理与此类似。 首先&#xff0c;让我们了解一下这个原理&#xff0c;其实非常简单。它主要依赖于磁力对悬浮物体的控制。基本原理如下&#xff1a;在浮子的正下方放置一个霍尔传感器。当传感器检测到浮子向…

Vue3+.NET6前后端分离式管理后台实战(二十五)

1&#xff0c;Vue3.NET6前后端分离式管理后台实战(二十五)已经在微信公众号更新&#xff0c;有兴趣的扫码关注一起交流学习。

Java面试题:Redis持久化问题

Redis持久化问题 RDB (Redis Database Backup File) Redis数据快照 将内存中的所有数据都记录到磁盘中做快照 当Redis实例故障重启时,从磁盘读取快照文件恢复数据 使用 save/bgsave命令进行手动快照 save使用主进程执行RDB,对所有命令都进行阻塞 bgsave使用子进程执行R…

多链路聚合设备在自然灾害应急能力提升工程基层防灾项目内的应用

在近几年信息技术的飞速发展&#xff0c;面对应急通信和指挥调度时需要移动化无线通信技术来做支撑&#xff0c;多链路聚合设备在中间的作用至关重要&#xff0c;实现从车到车、人到车、车到中心的多样化应用场景进行数据图像的无线传输和多节点组网方案需求&#xff0c;来满足…

(近似求π)可以使用以下公式计算 π:

package myjava; import java.math.*; public class cy {public static void main(String[]args){double pi;double sum0;double t0;int i;for(i1;i<10000;i){tMath.pow(-1,i)/(2.0*i-1.0);sumt;}System.out.println("PI"sum*4);} } 运行结果&#xff1a;

从零开始写 Docker(十七)---容器网络实现(中):为容器插上”网线“

本文为从零开始写 Docker 系列第十七篇&#xff0c;利用 linux 下的 Veth、Bridge、iptables 等等相关技术&#xff0c;构建容器网络模型&#xff0c;为容器插上”网线“。 完整代码见&#xff1a;https://github.com/lixd/mydocker 欢迎 Star 推荐阅读以下文章对 docker 基本实…