当前位置: 首页 > news >正文

「连载」边缘计算(二十一)02-26:边缘部分源码(源码分析篇)

(接上篇)

DeviceTwin struct组成剖析

该部分对DeviceTwin struct的组成进行剖析。接着devicetwin struct调用剖析的实例化DeviceTwin struct(dt := DeviceTwin{})往下剖析,进入DeviceTwin struct的定义,具体如下所示。

KubeEdge/edge/pkg/devicetwin/devicetwin.go

//DeviceTwin the module

type DeviceTwin struct {

context      *context.Context

dtcontroller *DTController

}

DeviceTwin struct的定义 *context.Context 和 *DTController两部分组成。其中,*context.Context可以参考8.3.2,这里不再赘述。下面重点剖析DTController

DTController的定义具体如下所示。

KubeEdge/edge/pkg/devicetwin/dtcontroller.go

//DTController controller for devicetwin

type DTController struct {

HeartBeatToModule map[string]chan interface{}

DTContexts        *dtcontext.DTContext

DTModules         map[string]dtmodule.DTModule

Stop              chan bool

}

DTController struct定义中发现\*dtcontext.DTContextdtmodule.DTModule的定义具体如下所示。

KubeEdge/edge/pkg/devicetwin/dtcontext/dtcontext.go

//DTContext context for devicetwin

type DTContext struct {

GroupID        string

NodeID         string

CommChan       map[string]chan interface{}

ConfirmChan    chan interface{}

ConfirmMap     *sync.Map

ModulesHealth  *sync.Map

ModulesContext *context.Context

DeviceList     *sync.Map

DeviceMutex    *sync.Map

Mutex          *sync.RWMutex

// DBConn *dtclient.Conn

State string

}

DTContext struct的定义可以看出,DTContext struct主要用来实现devicetwin的通信和缓存。DTModule.DTModule struct定义如下所示。

KubeEdge/edge/pkg/devicetwin/dtmodule/dtmodule.go

//DTModule module for devicetwin

type DTModule struct {

Name   string

Worker dtmanager.DTWorker

}

在 DTModule struct定义中,dtmanager.DTWorker是interface type,定义如下所示。

KubeEdge/edge/pkg/devicetwin/dtmanager/dtworker.go

//DTWorker worker for devicetwin

type DTWorker interface {

Start()

}

dtmanager.DTWorker的interface type可以推测DTModule有多种类型,而且都实现了DTWorker interface。KubeEdge/edge/pkg/devicetwin/dtmodule/dtmodule.go中的InitWorker()就是用来实例化DTModule的多种类型的,具体定义如下所示。

KubeEdge/edge/pkg/devicetwin/dtmodule/dtmodule.go

// InitWorker init worker

func (dm *DTModule) InitWorker(recv chan interface{}, confirm chan interface{}, heartBeat chan interface{}, dtContext *dtcontext.DTContext) {

switch dm.Name {

case dtcommon.MemModule:

dm.Worker = dtmanager.MemWorker{

Group: dtcommon.MemModule,

Worker: dtmanager.Worker{

ReceiverChan:  recv,

ConfirmChan:   confirm,

HeartBeatChan: heartBeat,

DTContexts:    dtContext,

},

}

...

}

InitWorker()函数的定义中可以梳理出,DTModuleMemWorkerTwinWorkerDeviceWorkerCommWorker四种类型。

到此,EdgeCoredevicetwin的struct调用剖析就全部结束了。

未完待续…… 

http://www.lryc.cn/news/306943.html

相关文章:

  • Unity(第四部)新手组件
  • 【JS】【Vue3】【React】获取鼠标位置的方法:JavaScript、Vue 3和React示例
  • [Docker 教学] 常用的Docker 命令
  • 小程序应用、页面、组件生命周期
  • Springboot中如何记录好日志
  • vm 虚拟机中ubuntu环境配置共享文件夹的方式
  • EMQX Enterprise 5.5 发布:新增 Elasticsearch 数据集成
  • 安全架构设计理论与实践
  • SQL注入漏洞解析--less-46
  • 【算法与数据结构】回溯算法、贪心算法、动态规划、图论(笔记三)
  • 【pytorch】常用代码
  • GB28181 —— Ubuntu20.04下使用ZLMediaKit+WVP搭建GB28181流媒体监控平台(连接带云台摄像机)
  • 图片录入设备、方式与质量对图片转Excel的影响
  • Linux:ACL权限,特殊位和隐藏属性
  • FL Studio21中文版本价格多少?值不值得购买?
  • 【论文阅读】ICCV 2023 计算和数据高效后门攻击
  • JavaAPI常用类03
  • SpringBoot/Java中OCR实现,集成Tess4J实现图片文字识别
  • 【深度学习目标检测】十九、基于深度学习的芒果计数分割系统-含数据集、GUI和源码(python,yolov8)
  • 骑砍战团MOD开发(48)-多人联机模式开发环境搭建
  • Java+SpringBoot+Vue+MySQL:美食推荐系统的技术革新
  • 【服务发现--ingress】
  • Yolov8有效涨点:YOLOv8-AM,添加多种注意力模块提高检测精度,含代码,超详细
  • 苹果分拣检测YOLOV8NANO
  • 使用 Verilog 做一个可编程数字延迟定时器 LS7211-7212
  • 戏说c语言文章汇总
  • 面试redis篇-12Redis集群方案-分片集群
  • 【Java EE初阶二十三】servlet的简单理解
  • c++ http操作接口
  • oracle官网下载早期jdk版本