Kuiper边云协同流数据处理集成方案设计
EMQ X Kuiper是由杭州映云科技有限公司开发,用Golang 实现的轻量级物联网边缘分析、流式处理开源软件,可以运行在各类资源受限的终端设备上。Kuiper 设计的主要目标是将在云端运行的实时流式计算框架(比如 Apache Spark,Apache Storm 和 Apache Flink 等)迁移到边缘。Kuiper 参考了上述云端流式处理项目的架构与实现,结合边缘流式数据处理的特点,采用了编写基于源 (Source),SQL (业务逻辑处理), 目标 (Sink) 的规则引擎来实现边缘端的流式数据处理。
本文介绍了EMQ X Kuiper与华为云IEF的集成解决方案,主要有:
- 如何利用 IEF systemrest->servicebus 通道进行 Kuiper 容器的管理,包括流、规则和插件的管理。
- 如何利用IEF eventbus->APIG,或者 eventbus-> DIS 数据通道,将 Kuiper 的流式处理结果发送至云端的华为 DIS 大数据服务,或者自有的应用等。
整体方案
上图中方案构成的系统完成了如下能力:
- 通过IEF构建的数据通道对边缘侧数据集成组件的生命周期进行管理。
- 通过IEF的配置通道对边缘侧数据集成规则进行配置。该规则为可处理流数据的SQL语句。
- 通过IEF将边缘侧获取到的数据转入相应的云服务或用户自己部署在云端的应用中。
- 边缘侧的Kuiper Container负责对接边缘侧其他系统获取数据。
- 边缘侧Kuiper的数据处理函数和数据源为插件式,可以由社区、ISV或华为等开发并预置。该插件也可以由IEF在云端进行管理进行插拔。
该方案由如下几个角色构成,在实际项目中可能其中的某些角色是合并为一个实体的:
集成测试User Story
针对这个解决方案,您可以设计如下User Story,并完成测试验证。
- 作为一个最终用户,我需要从华为云市场购买kuiper,以便使用kuiper提供的功能。
- 作为一个最终用户,我需要部署kuiper至我的边缘节点,以便使用kuiper提供的功能。
Kuiper后续将会上架华为云市场,暂时只能在IEF页面部署方式验证。
- 上传Kuiper镜像至华为云SWR服务。
- 在IEF中注册边1缘节点,具体方法请参见边缘节点 > 注册边缘节点。
- 在边缘节点安装边缘软件,具体方法请参见边缘节点 > 纳管边缘节点。
- 在边缘节点部署kuiper应用,具体方法请参见容器应用 > 创建边缘应用。
- 作为一个最终用户,我需要更新kuiper版本,以便使用新版本kuiper的功能。
- 作为一个最终用户,我需要部署一个新的插件至已存在的指定kuiper应用,以便使用Kuiper新增插件的能力.
kuiper需要提供一个API用于增加插件。
- 上传插件至OBS。
- 调用云上的API发送增加插件的请求到指定的kuiper。
- Kuiper收到请求后,到指定的地址下载插件并启动。
- 作为一个最终用户,我需要更新或删除已存在的指定kuiper应用上的插件,以便随时修改Kuiper的业务能力。
kuiper需要提供两个API:更新插件、删除插件。
- 上传插件至OBS(更新时的步骤)。
- 调用云上的API发送更新/删除插件的请求到指定的kuiper。
- Kuiper收到请求后,到指定的地址下载插件并更新或者直接删除。
- 作为一个最终用户,我需要配置kuiper应用的数据采集规则,以便收集需要的数据。
Kuiper需要创建一个API用于在边缘侧获取数据。
- 在IEF创建systemrest->servicebus的消息路由,详细方法请参见云端下发消息至边缘节点。
- 调用IEF接口发送Kuiper SQL配置请求至边缘侧指定的kuiper应用。
- 在IEF创建systemrest->servicebus的消息路由,详细方法请参见云端下发消息至边缘节点。
- 作为一个最终用户,我需要配置数据路由规则,使边缘产生的数据上传至云端的我的服务。
- 作为一个最终用户,我需要部署应用至云端,消费从kuiper上传的数据。
- 部署云端的应用。
- 注册上述云端应用消费数据的API至华为云APIG服务。
- 在IEF界面创建一个APIG类型的消息端点,请参见边云消息概述。
- 在IEF创建syseventbus->APIG的消息路由。
- kuiper发送数据。
- 作为一个最终用户,我需要查询kuiper的状态以及数据如何端到端传输的。