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

未完待续......

相关推荐
m0_650108243 分钟前
Vision-Language-Action 模型在自动驾驶中的应用(VLA4AD)
论文阅读·人工智能·自动驾驶·端到端自动驾驶·vla4ad·自动驾驶与多模态大模型交叉
爱笑的眼睛1110 分钟前
文本分类的范式演进:从统计概率到语言模型提示工程
java·人工智能·python·ai
星川皆无恙16 分钟前
基于知识图谱+深度学习的大数据NLP医疗知识问答可视化系统(全网最详细讲解及源码/建议收藏)
大数据·人工智能·python·深度学习·自然语言处理·知识图谱
美狐美颜SDK开放平台20 分钟前
自研还是接入第三方?直播美颜sdk与滤镜功能的技术选型分析
人工智能·美颜sdk·直播美颜sdk·美颜api·美狐美颜sdk
weixin_4166600721 分钟前
插件分享:将AI生成的数学公式无损导出为Word文档
人工智能·ai·word·论文·数学公式·deepseek
PM老周23 分钟前
DORA2025:如何用AI提升研发效能(以 ONES MCP Server 为例)
大数据·人工智能
皇族崛起25 分钟前
【众包 + AI智能体】AI境生态巡查平台边防借鉴价值专项调研——以广西边境线治理为例
大数据·人工智能
zhaodiandiandian44 分钟前
AI大模型:重构产业生态的核心引擎
人工智能·重构
沈浩(种子思维作者)1 小时前
百项可控核聚变实现方式的全息太极矩阵
人工智能