「连载」边缘计算(三十二)03-14:边缘部分源码(源码分析篇)

(接上篇)

EdgeCore edgemesh

前面对EdgeCore组件的edged、devicetwin、edgehub、eventbus、metamanager功能模块进行了分析,本节对EdgeCore组件的另一个功能模块edgemesh进行剖析。目前,KubeEdge官网没有edgemesh相关介绍,根据华为近期的边缘计算视频分享课程获得edgemsh的相关信息。edgemesh作为EdgeCore中节点级别的网络解决方案,主要实现了节点内的流量代理、节点间的流量代理和节点内的DNS解析3块功能。本节剖析这三块功能的具体实现,包括edgemesh Struct组成及注册、edgemesh业务逻辑剖析。

edgemesh Struct组成及注册

edgemesh模块的注册函数具体如下所示。

|-------------------------------------------------------------------------------|
| KubeEdge/edgemesh/pkg/module.go |
| // Register register edgemesh func Register() { core.Register(&EdgeMesh{}) } |

注册函数只干了一件事,就是将实例化的edgemesh struct加入到一个全局map中。EdgeMesh struct的定义具体如下所示。

|-------------------------------------------------------------------------------------------------|
| KubeEdge/edgemesh/pkg/module.go |
| //EdgeMesh defines EdgeMesh object structure type EdgeMesh struct { context *context.Context } |

EdgeMesh struct的定义比较简单,只有context一个属性。该属性用来与EdgeCore中的其他模块进行通信。

edgemesh 业务逻辑剖析

edgemesh模块的启动函数具体如下所示。

|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| KubeEdge/edgemesh/pkg/module.go |
| //Start sets context and starts the controller func (em *EdgeMesh) Start(c *context.Context) { em.context = c proxy.Init() go server.Start() // we need watch message to update the cache of instances for { if msg, ok := em.context.Receive(constant.ModuleNameEdgeMesh); ok == nil { proxy.MsgProcess(msg) klog.Infof("get message: %v", msg) continue } } } |

启动函数Start()做了如下4件事。

1)接收并保存通信管道;

2)初始化porxy;

3)启动服务;

4)通过一个for循环接收通信管道中关于edgemesh的信息并处理。

下面对第第2和第4件事展开剖析。

未完待续......

相关推荐
lizhihai_99几秒前
股市学习心得-六月的股市怎么应对
大数据·人工智能·科技·学习·区块链
明志数科3 分钟前
数据外包交付标准怎么定:机器人训练数据的质量管控方法论
人工智能
新新学长搞科研4 分钟前
【广东省博促会主办】2026年第七届先进材料与智能制造国际学术会议(ICAMIM 2026)
大数据·前端·数据库·人工智能·物联网
ALINX技术博客4 分钟前
ALINX VD100+Simulink 快速实现 FPGA 图像处理 Sobel 边缘检测
图像处理·人工智能·fpga开发
大树885 分钟前
本周液冷三件事 #2|Vera Rubin 227kW 全液冷量产 · 34 省 PUE 政策汇编 · 光模块也要液冷了
大数据·服务器·人工智能
2601_955781988 分钟前
HTML5 静态网站搭建 依托 OpenClaw 完成设计与部署
人工智能·教程分享·open claw部署·open claw本地部署
王莎莎-MinerU10 分钟前
从 OCR 到 Context Engineering:用 MinerU 搭一个可复现文档解析评测
人工智能·深度学习·机器学习·pdf·ocr·个人开发
叫我:松哥10 分钟前
基于卷积神经网络的静态手势语识别算法,在测试集上的识别准确率达到97.5%
人工智能·python·深度学习·神经网络·算法·cnn
ZHW_AI课题组11 分钟前
基于KNN的帕尔默企鹅种类预测分类
人工智能·机器学习·分类·数据挖掘
财迅通Ai11 分钟前
探路者:锚定端侧AI压缩黄金赛道,硬核科技开启成长新周期
人工智能·科技·探路者