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

(接上篇)

eventbus的具体逻辑剖析

eventbus的启动函数切入分析具体逻辑,具体如下所示。

KubeEdge/edge/pkg/eventbus/event_bus.go

func (eb *eventbus) Start(c *context.Context) {

// no need to call TopicInit now, we have fixed topic

eb.context = c

nodeID := config.CONFIG.GetConfigurationByKey("edgehub.controller.node-id")

...

mqttBus.NodeID = nodeID.(string)

mqttBus.ModuleContext = c

if eb.mqttMode >= bothMqttMode {

// launch an external mqtt server

externalMqttURL := config.CONFIG.GetConfigurationByKey("mqtt.server")

...

hub := &mqttBus.Client{

MQTTUrl: externalMqttURL.(string),

}

mqttBus.MQTTHub = hub

hub.InitSubClient()

hub.InitPubClient()

}

if eb.mqttMode <= bothMqttMode {

internalMqttURL := config.CONFIG.GetConfigurationByKey("mqtt.internal-server")

...

qos := config.CONFIG.GetConfigurationByKey("mqtt.qos")

...

retain := config.CONFIG.GetConfigurationByKey("mqtt.retain")

...

sessionQueueSize := config.CONFIG.GetConfigurationByKey("mqtt.session-queue-size")

...

if qos.(int) < int(packet.QOSAtMostOnce) || qos.(int) > int(packet.QOSExactlyOnce) || sessionQueueSize.(int) <= 0 {

klog.Errorf("mqtt.qos must be one of [0,1,2] or mqtt.session-queue-size must > 0")

os.Exit(1)

}

// launch an internal mqtt server only

mqttServer = mqttBus.NewMqttServer(sessionQueueSize.(int), internalMqttURL.(string), retain.(bool), qos.(int))

mqttServer.InitInternalTopics()

err := mqttServer.Run()

...

}

eb.pubCloudMsgToEdge()

}

eventbus的启动函数做了如下3件事。

1) 处理eventbus模块的公共配置,具体如下所示。

eb.context = c

nodeID := config.CONFIG.GetConfigurationByKey("edgehub.controller.node-id")

...

mqttBus.NodeID = nodeID.(string)

mqttBus.ModuleContext = c

接收并存储与EdgeCore其他模块通信的管道,从配置文件中获取所在节点的唯一标识。

2) 根据不同mqttMode启动与mqtt交互的不同实例,具体如下所示。

if eb.mqttMode >= bothMqttMode {

...

}

if eb.mqttMode <= bothMqttMode {

...

}

当 eb.mqttMode >= bothMqttModemqtt代理启动在eventbus之外,eventbus作为独立启动的mqtt代理的客户端与其交互;当eb.mqttMode <= bothMqttMode时,在eventbus内启动一个mqtt代理,负责与终端设备交互。

3)将部分的指令和事件下发到与eventbus相连的设备,具体如下所示。

eb.pubCloudMsgToEdge()

未完待续……  

  • 8
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值