EdgeX Foundry理论篇

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介:

总体架构

EdgeX总架构图.png

核心服务层

核心数据微服务

搜集持久化设备和传感器等边缘设备数据,支持导出到云。目前,数据本地存储交互通过REST APIs,未来会支持更多协议:MQTT, AMQP等。数据导出到Export Service layer,通过ZeroMQ、MQTT。persist.data=false,数据不存核心数据,直接通过消息队列到达Export Service layer。本服务是唯一能获得设备数据的服务。
查询数据流程图
core-data-查询数据.png
添加属性流程图
core-data添加属性.png

命令微服务

负责把命令从北端传到南端,不允许非法命令与设备交互。命令主要来自一下:其他微服务命令(本地边缘数据分析、规则引擎微服务)、其他应用命令(系统管理agent关闭一个设备)和外部系统命令(修改一系列设备设置文件)。命令微服务提供统一规范方式与设备通信,GET命令获取设备数据;PUT命令下发action或下发配置数据。命令微服务通过设备服务同设备交互,不直接交互设备。
查询命令流程图
Command-list commands.png
发送命令流程图
Command - send command.png

元数据微服务

元数据微服务主要包括管理设备配置文件,包括设备信息、设备数据结构类型和设备命令。每个被EdgeX 管理的设备,都在元数据有关联ID,设备关联设备配置文件和设备服务。元数据微服务管理设备服务信息,其他微服务通过设备服务同设备交互。设备服务,对应一特定设备协议,比如Modbus设备服务,负责管理所有Modbus设备。本服务是唯一能获得设备、设备配置和设备服务的微服务。数据本地存储交互通过REST API,未来会支持更多协议:MQTT, AMQP等
架构图
Meta Data  架构图.png
启动设备流程图
Meta Data 启动设备.png
添加设备流程图
Meta Data-添加设备.png

配置注册微服务

管理EdgeX Foundry微服务配置、执行参数和状态。提供微服务启动所需配置,如端口号等。各微服务启动,注册自身信息到本服务。对于注册服务,采用ping各微服务方式来探活, 频率每10 seconds一次。配置发生变更,本服务会及时通知对应微服务,配置信息会覆盖微服务内置配置信息,可支持动态切换环境,满足微服务架构动态扩展需求。在配置注册微服务不可用时,微服务可脱离本服务,使用自身内嵌配置启动。交互方式:RESTful APIs。 
配置注册服务交互图
注册微服务调用图.png

支撑服务层

通知告警微服务

告警通知微服务负责在设备发生故障,生成告警,发生告警到目的应端目前支持e-mail 和 REST 回调。通知分两种,NORMAL和CRITICAL,CRITICAL立刻发送通知到分发协调组,NORMAL等待消息调度器统一处理。可扩展,按需起调度器处理通知作业。
架构图
Alerts and Notifications 架构图.png
左边:API提供给其他微服务和应用调用,能通过 REST, AMQP, MQTT,或者其他标准应用协议,目前支持REST。
右边:消息订阅者通过订阅RESTful,订阅特定类型通知。消息接收者,在事件发生时,可通过SMS、, e-mail, REST callback, AMQP, MQTT等。
发现告警流程图
Alter Notify 危险通知发送.png
响应告警流程图
Alter and Notify Critical Resend Sequence.png

日志微服务

通过RESTful APIs提交日志请求、查询历史日志、移除历史日志,用LOGBack做日志框架,可以通过文件或MongoDB持久化日志。
架构图
Log-架构图.png
日志请求流程图
Logger-日志请求.png

调度微服务

EdgeX 的调度服务及其轻量,只负责定时清理设备数据。默认每30分钟执行一次,调用Core Data API执行清理任务

规则引擎微服务

规则引擎提供了一种边缘事件触发机制,监控边缘设备数据。符合条件,触发行为,通过命令服务下发指令。内核引擎采用Drools,由JBoss社区提供的开源规则引擎。规则引擎启动会自动注册到输出客户端注册服务,检测设备数据对于重要敏感案例,规则引擎可以直接对接核心数据微服务,需要设置配置文件,export.client=true。通过RESTful API动态添加规则。
架构图
Rule engine 流程图.png
添加规则流程图
规则引擎流程图.png

输出服务

客户端注册微服务

输出客户端注册微服务让客户端注册为数据接收者,按需过滤流转数据。Clients on-gateway:包括本地分析服务,事件处理器,规则引擎等。Clients off-gateway:经典企业云系统或网关聚合系统,提供历史数据和更深层次数据分析能力。通过REST API创建新请求,更新存在请求,删除请求。
架构图
输出服务架构图.png

分发微服务

分发微服务,基于EAI技术,管道过滤体系。通过消息队列,接收数据,过滤、传输和格式化数据,通过REST, MQTT, 0MQ分发数据到特定注册客户端。
分发流程图
Distribute - 流程图.png

系统管理服务

系统管理模块提供微服务安装、升级、启动、停止和监控功能

安全服务

支持AAA访问控制,AES256数据加密,唯一证书认证,HTTPS协议流程数据。

设备服务层

虚拟设备微服务

模拟不同协议设备,生成Events and Readings到核心数据微服务,通过H2 database存储虚拟设备资源。用户通过命令微服务下发命令到
。虚拟设备服务依赖数据微服务和元数据微服务,启动会ping核心数据和元数据微服务,超时时间600秒,未ping通,启动失败。虚拟设备服务启动初始化过程中,会在元数据微服务创建设备,设备配置,设备服务。
架构图
Virtual device 架构图.png

原理篇总体结合官网和自己理解
英文版请登入官网
https://wiki.edgexfoundry.org/display/FA/EdgeX+Foundry+Microservices+Architecture

相关实践学习
消息队列RocketMQ版:基础消息收发功能体验
本实验场景介绍消息队列RocketMQ版的基础消息收发功能,涵盖实例创建、Topic、Group资源创建以及消息收发体验等基础功能模块。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
目录
相关文章
|
3月前
|
Cloud Native Java 对象存储
揭秘微服务架构之争:Spring Cloud与Netflix OSS巅峰对决,谁将称霸弹性云原生时代?
近年来,微服务架构成为企业应用的主流设计模式。本文对比了两大热门框架Spring Cloud和Netflix OSS,探讨其在构建弹性微服务方面的表现。Spring Cloud依托Spring Boot,提供全面的微服务解决方案,包括服务注册、配置管理和负载均衡等。Netflix OSS则由一系列可独立或组合使用的组件构成,如Eureka、Hystrix等。两者相比,Spring Cloud更易集成且功能完善,而Netflix OSS则需自行整合组件,但灵活性更高。实际上,两者也可结合使用以发挥各自优势。通过对两者的对比分析,希望为企业在微服务架构选型上提供参考。
79 0
|
4月前
|
开发者 容器 Java
Azure云之旅:JSF应用的神秘部署指南,揭开云原生的新篇章!
【8月更文挑战第31天】本文探讨了如何在Azure上部署JavaServer Faces (JSF) 应用,充分发挥其界面构建能力和云平台优势,实现高效安全的Web应用。Azure提供的多种服务如App Service、Kubernetes Service (AKS) 和DevOps简化了部署流程,并支持应用全生命周期管理。文章详细介绍了使用Azure Spring Cloud和App Service部署JSF应用的具体步骤,帮助开发者更好地利用Azure的强大功能。无论是在微服务架构下还是传统环境中,Azure都能为JSF应用提供全面支持,助力开发者拓展技术视野与实践机会。
21 0
|
7月前
|
Kubernetes Dubbo Cloud Native
【Dubbo3技术专题】总体技术体系介绍及技术指南(序章)
【Dubbo3技术专题】总体技术体系介绍及技术指南(序章)
74 1
|
存储 运维 Cloud Native
《云上新势力 CLOUD IMAGINE》——Part 2 演讲/文章合集——文章5:《云原生驱动,打造融合通信的顶级触达力》(2)
《云上新势力 CLOUD IMAGINE》——Part 2 演讲/文章合集——文章5:《云原生驱动,打造融合通信的顶级触达力》(2)
120 0
|
人工智能 运维 Cloud Native
《云上新势力 CLOUD IMAGINE》——Part 2 演讲/文章合集——文章5:《云原生驱动,打造融合通信的顶级触达力》(3)
《云上新势力 CLOUD IMAGINE》——Part 2 演讲/文章合集——文章5:《云原生驱动,打造融合通信的顶级触达力》(3)
118 0
|
边缘计算 缓存 Kubernetes
阿里云云边一体容器架构创新论文被云计算顶会 ACM SoCC 录用
此次论文入选 ACM SoCC,是阿里云在云原生容器技术领域,拓展服务边界,实现云边协同的又一次创新。
359 0
阿里云云边一体容器架构创新论文被云计算顶会 ACM SoCC 录用
|
Kubernetes 负载均衡 Dubbo
【Dubbo3.0技术专题】总体技术体系介绍及技术指南(序章)
【Dubbo3.0技术专题】总体技术体系介绍及技术指南(序章)
319 0
【Dubbo3.0技术专题】总体技术体系介绍及技术指南(序章)
|
Kubernetes 负载均衡 Cloud Native
【云驻共创】华为云云原生之Kubernetes网络架构原理深度剖析(上)
【云驻共创】华为云云原生之Kubernetes网络架构原理深度剖析(上)
648 0
【云驻共创】华为云云原生之Kubernetes网络架构原理深度剖析(上)
|
Kubernetes 监控 Cloud Native
【云驻共创】华为云云原生之Kubernetes网络架构原理深度剖析(下)
【云驻共创】华为云云原生之Kubernetes网络架构原理深度剖析(下)
373 0
【云驻共创】华为云云原生之Kubernetes网络架构原理深度剖析(下)
|
Kubernetes 算法 大数据
2019年5月下旬最值得一读的9本技术书籍(微服务架构、算法、大数据等书籍)!
导读:读书,能让我们遇到好的书中好的方法、思想,不时的看看,就会让我们的头脑中思考的神经通路发达起来,慢慢地,我们就能够有了一些 积累,就会有了好的思维习惯。云栖社区小编为你整理出了2019年5月下旬最值得一读的9本技术书籍,其中涉及服务架构、算法、Flink等方面。
21265 0
AI助理

阿里云 AI 助理已上线!

快来体验一下吧。