随着车联网与 5G 技术的融合以及车辆智能化的发展,车联网的数据采集需求呈现爆发式增长。传统的车辆数据采集主要用于车辆的远程监测和故障诊断。随着车辆应用的丰富和智能化水平的提高,车辆数据采集逐渐应用到更多的场景,如研发用数据采集、数据统计和分析、规则引擎与报警系统、车辆实时控制等。
为什么需要灵活数采
现有的数据采集方案往往通过车载数据采集终端(T-BOX)固件中的采集功能或自行编写的采集程序进行车辆数据采集。通常采集程序所采集到的车身信息是固定且直接固化在车载终端上的。在智能车联网时代之前,采集的数据种类少、全量采集压力不大,这种做法是可行的。
随着车联网技术的发展,车辆整车网络构成也越来越复杂,可采集的车身信息多样化,全量采集数据量过大而且浪费宝贵的带宽资源,因此需要根据 TSP 应用的需求按需进行采集。此外,不同车型的汽车通常会有不同的数据,例如 CAN 总线的数据在不同车型上会有不同的 DBC 文件。固定采集程序无法移植,必须重新编写,并 OTA 升级采集程序。
总的来讲,固定采集程序存在以下问题:
- 采集的数据固定,无法灵活变更采集的项目。实际上随着车联网的发展,数据采集项目将根据应用呈现更多变化,固定的采集方式无法满足经常变动的真实需求。
- 采集信息解析配置固定,无法匹配新的车型或总线数据变化。例如,采集 CAN 总线数据的采集程序,无法变更 DBC 文件以匹配总线数据的变化。
- 扩展不易,新的传感器或总线协议需要重新开发。
因此,业界迫切需要一种灵活的、支持弱网情况的数据采集方案。
注:DBC(Data Base CAN)文件是由德国 Victor 公司发布的,它被用来描述单一 CAN 网络中各逻辑节点信息,依据该文件可以开发出监视和分析 CAN 网络中所有逻辑节点的运行状态。
如何实现灵活数采
针对固定数采程序缺陷,我们需要一个灵活数据采集引擎,并具备以下能力:
- 灵活数据埋点配置和规则,并可热更新和热启停数据采集规则。
- 多数据源对接和解析能力,例如 CAN 总线、HTTP 信号等。
- 灵活配置数据源解析的能力。以 CAN 总线为例,应当支持 DBC 文件的灵活加载和更新。
- 采集数据灵活分发的能力。可根据业务创建规则,将一部分数据本地保存,一部分数据回传云端。
- 弱网工况下,采集数据高效回传的能力。
- 足够轻量高效,从而可以运行在多种车型,包括车机资源受限的车型上。
基于大量的车联网用户案例和经验,EMQ 推出了基于 eKuiper 与 QUIC 协议的车云系统方案,实现了一套易部署可移植的车联网灵活数采方案。方案架构如下图所示。
在该方案中,我们采用开源边缘流式处理引擎 eKuiper 实现车载终端上的灵活数据采集功能,采用大规模分布式物联网 MQTT 消息服务器 EMQX 实现采集数据的连接、移动和处理以及车云一体的控制指令交互。在之前的车联网文章中,我们已经详细介绍了基于 EMQX 的车联网消息平台的架构设计,本文不再赘述。接下来,本文将以 eKuiper 为例,介绍如何实现车联网灵活数采。
灵活数采方案剖析
LF Edge eKuiper(简称 eKuiper)是开源的超轻量数据分析和流式计算引擎。eKuiper 兼容性强,可适配 X86 和 ARM 等多种 CPU 架构的车机终端。软件较轻量且可裁剪,核心包和初始运行内存在 10MB 级别,支持高吞吐低时延的各种数据处理和计算。在方案中,以部署于车机端的 eKuiper 为核心,可以实现近实时的灵活数据采集和处理转发等功能。
如下图所示,eKuiper 具备了数据流的接入、处理和流转能力。南向部分,eKuiper 支持接入各种协议的数据流,例如 CAN 总线、MQTT 协议、Socket(TCP 或 UDP)和 DDS 等。接入的数据可以在引擎内部根据用户定义的规则,进行数据的采集、转换、过滤和分析等数据处理工作,之后再将采集或处理的结果发送到各种北向的目的地中,例如存到本地的文件、数据库中以便后续车载应用使用;或是通过 HTTP/MQTT 等协议发送到云端或 TSP 应用端进行处理。
在灵活数采的场景中,假设 eKuiper 已部署到车机中,要完成一个数采任务,一般只需要两个步骤:
- 接入数据流
- 建立采集规则
在 eKuiper 中,这两个步骤无需编写代码,可使用 SQL 语句或者可视化 Flow 编辑器进行配置。
数据流接入
CAN(Controller Area Network)是最常见的车联网总线网络。本文以接入和解析 CAN 数据为例,介绍 eKuiper 如何实现车载数据流的接入。
在 eKuiper 中提供了CAN 数据源,其中主要实现了两个能力:
- 连接协议
- 根据 DBC 解码 CAN 报文
连接协议支持
若 eKuiper 可以直接连接 CAN 总线,则可通过 CAN 协议建立到车载总线的连接,获取总线数据。出于安全的原因,eKuiper 也经常被部署到与总线隔离的硬件上。例如,eKuiper 部署在 MPU 中;而在 MCU 中部署 CAN 总线连接应用,通过 TCP、UDP 或者 MQTT 协议等,将报文透传出来。eKuiper 同样支持通过这些协议进行连接,获取总线数据报文。
灵活 CAN 报文解码
我们从总线接收到的报文为二进制编码的数据,人类难以阅读。CAN DBC 是一种文本文件,用于 CAN 报文的描述文件。通过读取 DBC 的描述信息,我们可以把 CAN 报文的数据解析为物理值的信息。例如,一段 CAN ID 0x208 的数据 0x0500000000000000,根据 DBC 的描述信息可能解析为一系列信号,可表示为键值对或者 JSON 串 {"temperature":10, "voltage": 100}
等。
eKuiper 的 CAN 数据源可将数据解析为可读的键值对,这样编写数据采集规则的时候,可以直接选取可读的信号,大大简化采集逻辑的编写。CAN 报文解析功能具有极大的灵活性,可以动态地更新 DBC 文件以适配不同的车型或升级车载总线数据而无需编码。
CAN 报文解析的灵活性主要体现在如下方面:
- DBC 文件可配置,可热更新
- 支持多个 DBC 文件
- 支持 CAN FD 格式
- 支持白名单和 container ID 映射
基于灵活的报文解码支持,当总线数据结构改变或者更改车型时,仅需更新 DBC 文件即可适配。
在 eKuiper 中,流(stream)是用于定义数据接入的一个实体。我们可使用如下的 SQL 语句,定义一个接入 CAN 总线的数据流。
CREATE STREAM canDemo () WITH ( Type="can", CONF_KEY="test", SHARED="TRUE")
该语句定义了一个名为 canDemo 的流,其类型为can
,即接入 CAN 总线的数据源类型;CONF_KEY 表示接入配置定义在名为 test
的配置中,其中可配置使用的 DBC 文件地址等;SHARED 设置为 true,表示使用该数据流的所有规则共享一份数据,确保解码只会进行一次。
该流将接入解析 CAN 总线数据,得到 JSON 数据流。接下来,应用开发人员可以在其上创建多条规则,定义如何采集数据。
接入扩展
随着汽车智能化程度的提高,车载的传感器和数据总线的数量和种类越来越多。eKuiper 提供了扩展机制,用户可以编写插件实现新的协议或私有协议的接入和解析。安装后的插件遵循使用逻辑,应用开发人员可以与使用原有的数据流类型相同的方法创建数据流。
灵活配置采集规则
前文中我们已经创建了连接 CAN 总线的数据流,接下来我们可以建立多个数据采集规则进行灵活的数采。本节介绍一些常见的采集规则。规则内容为 JSON 文本数据,可通过 REST API 等方式进行规则的动态下发管理,具体管理方法将在下一节介绍。
eKuiper 的规则分为两个部分,其中 SQL 用于编写业务逻辑,例如需要采集哪些数据、对数据做哪些处理;Actions 部分用于描述规则命中后执行的动作,例如存储到本地文件或者发送到云端 MQTT 的某个主题中。假设上一节创建的数据流 canDemo 中,总线中的数据解析为包含发动机相关数据如发动机转速(rpm)、进气温度(inletTemperature)、进气压力(inletPressure)以及电池相关数据,如电池电压(voltage),电池电流(current)等数据的键值对数据,如 {"rpm":2000, "inletTemperature":230, "inletPressure":27, "voltage":15,"currency":2}
。下列配置的规则将针对这个总线数据进行采集。
采集指定的信号
本规则可实时采集发动机的信号并发送到 MQTT topic
collect
中。规则通过 SQL 语句中的 SELECT 子句定义了需要采集的数据点。{ "id": "ruleCollect", "sql": "SELECT rpm, inletTemperature, inletPressure FROM canDemo", "actions": [{ "mqtt": { "server": "tcp://yourserver:1883", "topic": "collect" } }] }
采集有变化的信号
某些信号可能变化周期比较长,全部采集的话大部分为重复值,占据存储和带宽。eKuiper 提供了内置的变化采集函数
CHANGED_COLS
,可以仅采集信号数值变化的情况。下面的示例规则中,我们采集了电池的变化信息,并保存在本地文件中。{ "id": "ruleChangeCollect", "sql": "SELECT CHANGED_COLS(\"\", true, voltage, currency) FROM canDemo", "actions": [{ "file": { "path": "/tmp/cell" } }] }
根据事件采集
某些信号只有在特定的情况下才需要采集,例如碰撞后采集相关的数据。eKuiper 中可以灵活设置采集的条件。以下的规则中,当电池电压异常(不在10到20之间)的情况下,采集所有数据到 MQTT 的 Topic
exception
中。{ "id": "ruleExpCollect", "sql": "SELECT * FROM canDemo WHERE voltage NOT BETWEEN 10 AND 20 ", "actions": [{ "mqtt": { "server": "tcp://yourserver:1883", "topic": "exception" } }] }
车云一体规则管理
规则构思完成后,需要进行动态下发和管理。EMQ 提供了车云一体的规则管理控制台,用户可以在里面进行规则的编写、下发和状态管理。管理控制台可以在云端集中管理多个车机边缘节点。
规则编写
管理控制台上提供了规则编写的图形界面。如下图所示,用户可以在界面上填入规则的 ID、SQL 和动作等。提交后,规则即可下发到对应车机节点。
我们也将提供规则编写的可视化 Flow 编辑器界面。用户可采用拖拽的方式编写自己的业务规则。
规则管理
eKuiper 中的规则都是可灵活管理的。规则可以热添加、热更新和热启停。在管理控制台中,用户可以查看规则的运行状态,进行规则的修改、启停、删除等操作。
云端集中管理
通过云端可集中管理在车辆边缘端上的数据分析应用。
- 大规模在线车辆支持:基于 EMQX Enterprise,百万级别在线车辆支持
- 车辆在线自动更新应用:支持离线车辆应用更新、升级;车辆在线后自动更新应用,并报告状态
- 车辆离线后状态查询支持:车辆离线状态下可获取应用部署的最后状态
- HTTP Rest API 服务接口支持:同步 HTTP 接口,接入前端应用 (web & mobile)
更多可能
eKuiper 作为一个通用的流式计算引擎,除了实现数据采集之外,还可以实现很多边缘计算功能,充分利用车载终端算力。例如,eKuiper 可支持下列功能:
- 数据变换和格式化,例如将传输信号由整型转换回浮点型,或者将信号格式化为目标系统要求的格式。
- 数据分析,例如计算一段时间内的平均值等统计值。
- SOA 服务调用,实现场景联动,例如根据车内温度自动开关空调。
- AI/ML 算法集成,例如根据采集到的信号识别用户的充电意图等。
更多功能欢迎读者们自行探索。
总结
车联网软硬件技术大发展的浪潮下,传统的固定数据采集方案难以应对层出不穷的采集需求。通过本文介绍的基于 eKuiper 与 EMQX 的车云系统方案,可实现端到端的灵活数据采集需求。eKuiper 采用基于文本型业务处理应用下发,避免复杂 OTA 升级,帮助车联网企业实现灵活的数据采集以及高效的车云数据协同。
版权声明: 本文为 EMQ 原创,转载请注明出处。
原文链接:https://www.emqx.com/zh/blog/how-to-achieve-flexible-data-collection-for-internet-of-vehicles
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。