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

(接上篇)

获取cloudhub client,具体如下所示。

|-----------------------------------------------------------------------------------|
| cloudHubClient, err := clients.GetClient(ehc.config.Protocol, config.GetConfig()) |

clients.GetClient()函数定义具体如下所示:

|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| KubeEdge/edge/pkg/edgehub/factory.go |
| //GetClient returns an Adapter object with new web socket func GetClient(clientType string, config *config.EdgeHubConfig) (Adapter, error) { switch clientType { case ClientTypeWebSocket: websocketConf := wsclient.WebSocketConfig{ ... } return wsclient.NewWebSocketClient(&websocketConf), nil case ClientTypeQuic: quicConfig := quicclient.QuicConfig{ ... } return quicclient.NewQuicClient(&quicConfig), nil default: klog.Errorf("Client type: %s is not supported", clientType) } return nil, ErrorWrongClientType } |

从GetClient()函数定义可以知道,该函数定义了ClientTypeWebSocket、ClientTypeQuic两种client类型,两者都实现了Adapter interface。遇到Adapter类型的client变量时,记得对应此处的ClientTypeWebSocket、ClientTypeQuic。

cloud client初始化,具体如下所示。

|---------------------------|
| err = ehc.chClient.Init() |

ehc.chClient.Init()函数对应获取cloudhub client中ClientTypeWebSocket、ClientTypeQuic的Init()方法。

向EdgeCore各模块广播已经连接成功的消息,具体如下所示。

|-------------------------------------------------------------|
| // execute hook func after connect ehc.pubConnectInfo(true) |

将从cloud部分收到的消息转发给指定edge部分的指定模块,具体如下所示。

|----------------------|
| go ehc.routeToEdge() |

将从edge部分的消息转发给cloud部分,具体如下所示。

|-----------------------|
| go ehc.routeToCloud() |

向cloud部分发送心跳信息,具体如下所示。

|--------------------|
| go ehc.keepalive() |

剩下的步骤都是在edgehub模块退出时的一些清理操作。

到此,EdgeCore组件的edgehub模块的剖析就结束了。

未完待续......

相关推荐
淡漠的蓝精灵几秒前
mem0aimem0,给AI加记忆层的开源方案
人工智能·其他
精益数智小屋5 分钟前
什么是进销存库存表?进销存库存表包含哪些内容?
大数据·运维·数据库·人工智能·安全
新加坡内哥谈技术8 分钟前
推理架构的转变
人工智能
零梦ing9 分钟前
解决claude下载问题
人工智能
2601_9577808410 分钟前
Agent记忆系统架构设计与工程实践:从短期暂存到长期持久化
大数据·网络·人工智能·架构·agent
weixin_66810 分钟前
Windows 上通过 WSL2 部署 Qwen3-ASR-0.6B - AI
人工智能·windows
聚铭网络12 分钟前
聚铭网络入选数说安全《AI重塑网络安全:网络安全智能化产品与市场报告》
网络·人工智能·安全
小小测试开发12 分钟前
OpenAI Daybreak 深度解析:AI 驱动的漏洞检测与修复实战指南
人工智能
_Evan_Yao14 分钟前
责任链模式在Agent编排中的应用:让AI Agent学会“踢皮球”
java·人工智能·后端·责任链模式