「连载」边缘计算(三十二)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件事展开剖析。

未完待续......

相关推荐
就是有点傻2 分钟前
机器视觉图像处理学习第一天
人工智能·计算机视觉
Aaron15882 分钟前
数字波束合成DBF与模拟波束合成ABF对比浅析
大数据·人工智能·算法·硬件架构·硬件工程·信息与通信·信号处理
MRDONG13 分钟前
Prompt 到 Context 再到 Harness:AI 工程范式的三次跃迁
人工智能·语言模型·prompt
weixin_408099676 分钟前
【实战案例】电商自动化:如何用 OCR API 批量识别商品图片文字?(完整方案 + 代码示例)
人工智能·ocr·api·文字识别·电商ocr·商品图片文字识别·ocr 批量识别
非晓为骁6 分钟前
我用AI给自己做了一场深度复盘
人工智能·ai·复盘
新缸中之脑6 分钟前
如何让AI推荐你
人工智能
AI帮小忙8 分钟前
OpenClaw 清除对话记录 & 常用命令速查手册
人工智能
wei_shuo10 分钟前
基于 Rokid 灵珠 AI 平台:OCR 工作流与学术智能体搭建实操指南
人工智能·语音识别·rokid
天一生水water10 分钟前
什么是机器学习中的类别不平衡
人工智能·机器学习
jinanwuhuaguo15 分钟前
OpenClaw 2026年4月升级大系深度解读剖析:从“架构重塑”到“信任内建”的范式跃迁
android·开发语言·人工智能·架构·kotlin·openclaw