Kubeedge Edged概述

Overview

EdgeD是管理节点生命周期的边缘节点模块。它可以帮助用户在边缘节点上部署容器化的工作负载或应用程序。这些工作负载可以执行任何操作,从简单的远程遥测数据操作到分析或ML推理等等。使用kubectl云端的命令行界面,用户可以发出命令来启动工作负载。

通过容器运行时接口Container Runtime Interface(CRI)支持几种符合OCI的运行时runtimes。请参阅KubeEdge运行时配置,以获取有关如何配置边缘以利用其他运行时的更多信息。

有许多模块协同工作以实现edged的功能。

EdgeD Overall

Fig 1: EdgeD Functionalities

Pod Management

它是pod添加,删除和修改的句柄。它还使用pod status manager和pleg跟踪pod的运行状况。其主要工作如下:

  • 接收并处理来自metamanager的pod添加/删除/修改消息。
  • 处理单独的工作队列以添加和删除容器。
  • 处理工作程序例程以检查工作程序队列以执行pod操作。
  • 分别为配置映射和秘密保留单独的缓存。
  • 定期清理孤立的吊舱orphaned pods

Pod Addition Flow

Fig 2: Pod Addition Flow

Pod Deletion Flow

Fig 3: Pod Deletion Flow

Pod Updation Flow

Fig 4: Pod Updation Flow

Pod Lifecycle Event Generator生命周期事件生成器

该模块有助于监视吊舱pod的边缘状态。每隔一秒钟,通过使用活动性和就绪状态的探测,会使用窗格状态管理器为每个窗格更新信息。

PLEG Design

Fig 5: PLEG at EdgeD

CRI for edged

Container Runtime Interface (CRI) – a plugin interface which enables edged to use a wide variety of container runtimes like Docker, containerd, CRI-O, etc., without the need to recompile. For more on how to configure KubeEdge for container runtimes, see KubeEdge runtime configuration.

容器运行时接口Container Runtime Interface(CRI)–一个插件接口,使边缘用户无需重新编译即可使用各种容器运行时runtimes,例如Docker,contained,CRI-O等。有关如何为容器运行时配置KubeEdge的更多信息,请参见KubeEdge运行时配置

Why CRI for edged?

为了在以下情况中需要CRI支持边缘化的多个容器运行时runtimes:

  • 在无法运行现有Docker运行时的资源受限边缘节点上支持轻量级容器运行时runtime。
  • 在边缘节点上支持多个容器运行时runtime,例如Docker,contained,CRI-O等。

稍后将考虑对具有暂停容器和IP的相应CNI的支持。

CRI Design

Fig 6: CRI at EdgeD

Secret Management

在边缘,秘密是分开处理的。对于添加,删除和修改之类的操作,有单独的配置消息和接口集。使用这些接口,机密会在缓存存储中更新。下面的流程图说明了消息流。

Secret Message Handling

Fig 7: Secret Message Handling at EdgeD

Edged使用MetaClient模块从MetaManager获取机密。如果边缘查询尚未存储在MetaManager中的新机密,则该请求将转发到云。在发送包含机密的响应之前,MetaManager将其存储在本地数据库中。随后将从数据库检索对同一密钥的查询,从而减少了等待时间。下面的流程图显示了如何从MetaManager和云中获取机密。它还描述了机密如何存储在MetaManager中。

Query Secret

Fig 8: Query Secret by EdgeD

Probe Management

探针管理分别创建两个探针,以准备就绪和活动,以便吊舱监视容器。就绪探针可通过监视容器何时达到运行状态来提供帮助。活动性探针可通过监视吊舱的健康状况(指示吊舱处于打开还是关闭状态)来提供帮助。如前所述,PLEG模块使用其服务。

ConfigMap Management

在有边缘的情况下,ConfigMap也被单独处理。对于添加,删除和修改之类的操作,有单独的配置消息和接口集。使用这些接口,可以在缓存存储中更新ConfigMap。下面的流程图说明了消息

ConfigMap Message Handling

Fig 9: ConfigMap Message Handling at EdgeD

Edged使用MetaClient模块从MetaManager获取ConfigMap。如果边缘查询尚未存储在MetaManager中的新ConfigMap,则该请求将转发到云。在发送包含ConfigMap的响应之前,MetaManager将其存储在本地数据库中。随后将从数据库检索对同一ConfigMap密钥的查询,从而减少了延迟。下面的流程图显示了如何从MetaManager和Cloud获取ConfigMap。它还描述了ConfigMap如何存储在MetaManager中。Query Configmaps

Fig 10: Query Configmaps by EdgeD

Container GC

The container garbage collector is an edged routine which wakes up every minute, collecting and removing dead containers using the specified container gc policy. The policy for garbage collecting containers is determined by three variables, which can be user-defined:

容器垃圾收集器是一个边缘例程,它每分钟唤醒一次,使用指定的容器gc策略收集和删除死容器。垃圾收集容器的策略由三个变量确定,可以由用户定义:

  • MinAge 是可以收集垃圾的最小年龄,零是无限制的。
  • MaxPerPodContainer 是允许任何单个吊舱(UID,容器名称)对具有的失效容器的最大数量,不超过零且没有限制。
  • MaxContainers是死容器总数的最大数量,无限制地小于零。通常,最旧的容器会先被移除。

Image GC

图像垃圾收集器是一个边缘程序,每5秒唤醒一次,并根据使用的策略收集有关磁盘使用情况的信息。垃圾收集图像的策略考虑了两个因素:HighThresholdPercent和LowThresholdPercent。磁盘使用率高于高阈值将触发垃圾回收,垃圾收集将尝试删除未使用的映像,直到达到低阈值为止。首先删除最近最少使用的图像。

Status Manager

状态管理器是一个独立的边缘例程,它每10秒收集一次pod状态,并使用metaclient接口将该信息转发到云。

Status Manager Flow

Fig 11: Status Manager Flow

Volume Management

卷管理器作为边缘例程运行,该边缘例程基于在边缘节点上安排的容器,带出要附加/安装/卸载/分离哪些卷的信息。

在启动Pod之前,将附加并安装Pod规格中引用的所有指定卷,直到阻塞该流及其其它操作。

MetaClient

Metaclient是Metamanger for Edge的接口。它有助于从Metamanager或云中获取ConfigMap和秘密详细信息。它还向metamanger发送同步消息,节点状态和pod状态到云。

Kubeedge Edged概述的更多相关文章

  1. KubeCon深度洞察 | KubeEdge开源首秀

    以下内容根据华为云DJ在KubeCon Shanghai Demo Session演讲实录整理而成. KubeEdge Demo Show 11月15日上午Huawei宣布了KubeEdge项目开源, ...

  2. KubeEdge,一个Kubernetes原生边缘计算框架

    ​KubeEdge成为第一个Kubernetes原生边缘计算平台,Edge和云组件现已开源! 开源边缘计算正在经历其业界最具活力的发展阶段.如此多的开源平台,如此多的整合以及如此多的标准化举措!这显示 ...

  3. KubeEdge v0.2发布,全球首个K8S原生的边缘计算平台开放云端代码

    KubeEdge开源背景 KubeEdge在18年11月24日的上海KubeCon上宣布开源,技术圈曾掀起一阵讨论边缘计算的风潮,从此翻开了边缘计算和云计算联动的新篇章. KubeEdge即Kube+ ...

  4. KubeEdge云边协同设计原理

    云端组件CloudCore与k8s Master的关系 从黑盒角度看,CloudCore就是k8s的一个插件,它是非侵入的来扩展k8s的一部分功能,将原来云上的节点映射到边缘端进行管理,一个Cloud ...

  5. KubeEdge边缘自治设计原理

    这一篇内容主要是KubeEdge中边缘节点组件EdgeCore的原理介绍. KubeEdge架构-EdgeCore 上图中深蓝色的都是kubeedg自己实现的组件,亮蓝色是k8s社区原生组件.这篇主要 ...

  6. 边缘计算 KubeEdge+EdgeMash

    简介 KubeEdge是面向边缘计算场景.专为边云协同设计的业界首个云原生边缘计算框架,在 Kubernetes 原生的容器编排调度能力之上实现了边云之间的应用协同.资源协同.数据协同和设备协同等能力 ...

  7. KubeEdge 1.12版本发布,稳定性、安全性、可扩展性均带来大幅提升

    摘要:2022年9月29日,KubeEdge发布1.12版本.新版本新增多个增强功能,在扩展性.稳定性.安全性上均有大幅提升. 本文分享自华为云社区<KubeEdge 1.12版本发布,稳定性. ...

  8. 【AR实验室】ARToolKit之概述篇

    0x00 - 前言 我从去年就开始对AR(Augmented Reality)技术比较关注,但是去年AR行业一直处于偶尔发声的状态,丝毫没有其"异姓同名"的兄弟VR(Virtual ...

  9. Recurrent Neural Network系列1--RNN(循环神经网络)概述

    作者:zhbzz2007 出处:http://www.cnblogs.com/zhbzz2007 欢迎转载,也请保留这段声明.谢谢! 本文翻译自 RECURRENT NEURAL NETWORKS T ...

随机推荐

  1. mac系统 php 7.2安装memcache扩展

    memcache的安装 下载地址:https://github.com/websupport-sk/pecl-memcache/archive/php7.zip wget https://github ...

  2. sublime text 快捷键的使用大全

    多行选择后按下ctrl+/ 选择类 Ctrl+D 选中光标所占的文本,继续操作则会选中下一个相同的文本. Alt+F3 选中文本按下快捷键,即可一次性选择全部的相同文本进行同时编辑.举个栗子:快速选中 ...

  3. python 利用opencv去除图片水印

    python 去除水印"人工"智能去除水印 这两天公司来了一个新的需求--去除水印,对于我一个从未接触过的这种事情的人来说,当时我是蒙的.不过首先我就去搜索了一下是否有该种合适的功 ...

  4. hdu 5059 判断数字表示方式以及范围合法(int型之内)

    题意:       给你一个串和两个整数a,b,问你这个串表示的数字是否合法,并且在a,b之间, 和法的要求是无论是正数还是负数都没有前导0,并且注意 -0 是不合法的. 思路:       写了将近 ...

  5. C#-自动获取IP

    //自动获取ip rip是个下拉列表 public void GetIp() { try { string strHostName = Dns.GetHostName(); //得到本机的主机名 IP ...

  6. Docker Swarm删除节点

    节点上的主机如果想离开的话,可以自己直接执行docker swarm leave 然后你可以发现,原本跑在自己上面的容器被转移到别的容器上了.此时如果在manager节点上docker node ls ...

  7. jquery遍历json的几种方法

    for循环: 1 <script> 2 var obj = { 3 "status":1, 4 "bkmsg":"\u6210\u529f ...

  8. CCNA 第五章 变长子网掩码、汇总和TCP/IP故障排除

    1:VLSM:即变长子网掩码,使用长度不同的子网掩码将大型网络划分为众多子网,以满足不同类型的网络设计. 2:运行老式的路由器和例如:RIP V1协议的网络不能使用VLSM,因为它使用分类路由器选择. ...

  9. 2020BUAA 软工-结对作业

    结对作业 项目 内容 北航2020软工 班级博客 作业要求 具体要求 1.在文章开头给出教学班级和可克隆的 GitHub 项目地址(例子如下).(1') 教学班级 005 项目地址 GitHub 2. ...

  10. 【转】java-selenium三种等待方式

    方式1: 线程等待:Thread.sleep(xxxx) 只要在case中加入sleep就会强制等待设置的时间后才会执行之后的命令,这种等待一般适用于调试脚本的时候. java代码: //等待3秒 T ...