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

(接上篇)

EdgeCore m atamanager

前面对EdgeCore组件的edged、devicetwin、edgehub、eventbus功能模块进行了分析,本节对EdgeCore组件的另一个功能模块metamanager进行剖析。metamanager作为EdgeCore中的edged模块与edgehub模块进行交互的桥梁,除了将edgehub的消息转发给edged,还对一些必要的数据通过SQLite进行缓存,在某种程度上实现了KubeEdge的offline mode。本节就对metamanager所涉及的SQLite数据库相关逻辑和业务逻辑进行剖析,metamanager数据库相关逻辑剖析,metamanager业务逻辑剖析。

metamanager 数据库相关逻辑剖析

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

|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| KubeEdge/edge/pkg/metamanager/module.go |
| //constant metamanager module name const ( MetaManagerModuleName = "metaManager" ) ... // Register register metamanager func Register() { dbm.RegisterModel(MetaManagerModuleName, new(dao.Meta)) core.Register(&metaManager{}) } |

注册函数Register()做了两件事。

  1. 在SQLite中的数据库中初始化metaManager表;

2)注册已经初始化的metamanager。

下面深入剖析 在SQLite中的数据库中初始化metaManager表相关内容。dbm.RegisterModel()定义具体如下所示。

|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| KubeEdge/edge/pkg/common/dbm/db.go |
| //RegisterModel registers the defined model in the orm if model is enabled func RegisterModel(moduleName string, m interface{}) { if isModuleEnabled(moduleName) { orm.RegisterModel(m) ... } else { ... } } |

RegisterModel()函数是对[GitHub.com/astaxie/beego/orm](https://GitHub.com/astaxie/beego/tree/develop/orm)的封装。

回到在SQLite中的数据库中初始化metaManager表,下面深入剖析metaManager表的具体定义dao.Meta。dao.Meta定义具体下所示。

|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| KubeEdge/edge/pkg/metamanager/dao/meta.go |
| // Meta metadata object type Meta struct { // ID int64 `orm:"pk; auto; column(id)"` Key string `orm:"column(key); size(256); pk"` Type string `orm:"column(type); size(32)"` Value string `orm:"column(value); null; type(text)"` } |

metaManager表的具体定义包含Key、Type和Value三个字段,具体含义如下。

1) Key:meta的名字;

2) Type: meta对应的操作类型;

3) Value:具体的meta值;

与Meta Struct的定义在同一文件内,还有对metaManager表的一些操作定义,如SaveMeta、DeleteMetaByKey、UpdateMeta、InsertOrUpdate、UpdateMetaField、UpdateMetaFields、QueryMeta、QueryAllMeta。

未完待续......

相关推荐
koo36418 小时前
pytorch环境配置
人工智能·pytorch·python
模型启动机1 天前
黄仁勋GTC开场:「AI-XR Scientist」来了!
人工智能·ai·大模型
k***1951 天前
自动驾驶---E2E架构演进
人工智能·架构·自动驾驶
Techblog of HaoWANG1 天前
目标检测与跟踪 (4)- 基于YOLOv8的工业仪器仪表智能读数与状态检测算法实
人工智能·视觉检测·智能制造·yolov8·工业检测·指针式仪表·仪器仪表检测
1***Q7841 天前
深度学习技术
人工智能·深度学习
KKKlucifer1 天前
2025 国产化数据分类分级工具实测:国产化适配、多模态识别与动态分级能力深度解析
人工智能·分类·数据挖掘
虹科网络安全1 天前
从AI模型到云生态:构建系统化的企业AI安全管理体系【系列文章(3)】
人工智能·安全
b***67641 天前
Springboot3 Mybatis-plus 3.5.9
数据库·oracle·mybatis
互联网江湖1 天前
这个Q3,百度开始AI
人工智能·百度
Leinwin1 天前
微软与Anthropic深化战略合作,在Azure Foundry平台部署Claude系列AI模型
人工智能·microsoft·azure