时序数据库 TDengine 支持集成开源的物联网平台 ThingsBoard

server/2024/10/25 18:30:52/

Thingsboard 中“设备配置”和“设备”的关系是一对多的关系,通过设备配置为每个设备设置不同的配置,每个设备都会有一个与其关联的设备配置文件。等等,这不就是TDengine 中超级表的概念:

超级表是一种特殊的表结构,用于代表一类具有相同数据模式的数据采集点。一个超级表有多个子表,一个子表只能隶属于一个超级表。

因此,将两者有机结合起来:TDengine 中创建超级表作为“设备配置”,Thingsboard 中添加设备则自动在TDengine 中创建子表,伟大的设计殊途同归。

灵魂的碰撞

安装部署

安装过程可以直接参考官方安装教程:Installing ThingsBoard CE on Ubuntu Server | ThingsBoard Community Edition

但是有两点需要注意:

  • 请点击这里,联系我们获取适配版本。
  • 配置文件增加 TDengine 相关连接配置:
# spring.tdengine
export TDENGINE_URL=jdbc:TAOS-RS://127.0.0.1:6041/thingsboard
export TDENGINE_USERNAME=root
export TDENGINE_PASSWORD=taosdata
export TDENGINE_STR_LEN=1024
export TDENGINE_STR_COL_MAX=65517
export TDENGINE_STR_TAG_MAX=16382

操作步骤

1.创建“设备配置”

以一个车辆管理系统为例,需要记录车辆的车牌号、数据上报时间、经度、纬度、车速这几个变量。因此,我们调用接口来创建一个新的“设备配置”。

curl -X POST 'http://127.0.0.1:8080/api/deviceProfile' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer $YOUR_JWT_TOKEN_HERE' \
--data-raw '{"name": "truck","type": "DEFAULT","image": null,"defaultQueueName": null,"transportType": "DEFAULT","provisionType": "DISABLED","description": "","profileData": {"configuration": {"type": "DEFAULT"},"transportConfiguration": {"type": "DEFAULT"},"alarms": null,"provisionConfiguration": {"type": "DISABLED"}},"tableInfo": {"columns": [{"name":"longtitude","type":"double","len":10},{"name":"latitude","type":"double"},{"name":"speed","type":"float"}],"tags": [{"name":"license_plate_number","type":"nchar","len":8}]}
}'

Thingsboard 中成功创建名称为“profileStable” 的“设备配置”:

数据库中成功创建超级表:

2.添加新设备

选择已有配置“profileStable”,创建新的设备。

成功创建了一个名叫“测A88888″ 的设备,具体的子表名称可以通过“复制设备ID” 查看。

3.测试写入数据

直接通过访问令牌,调用接口发送数据

curl -X POST 'http://127.0.0.1:8080/api/v1/$YOU_DEVICE_TOKEN/telemetry' \
--header 'Content-Type: application/json' \
--data-raw '{"license_plate_number":"京A88888","longtitude":108.938744,"latitude":34.368150,"speed":60}'

界面中更新数据

数据库中也写入了最新的记录

业务展示

场景一:车辆实时定位追踪

  • 数据采集:车辆GPS定位信息每秒传输到Thingsboard。
  • 数据存储:在TDengine中创建表存储定位数据。
  • 数据展示:在Thingsboard创建地理位置图表,展示车辆实时位置。

场景二:车队维护预警

按日生成车辆每日超速次数。

  • 创建流计算:在TDengine 中创建流计算
create stream high_speed fill_history 1 into high_speed subtable(concat('tb_', device_name)) as
select_wstart as 日期,count(speed) as 超速次数,device_name as 设备名称
from`1e169050-86e6-11ef-a5cf-2de52a1b0351`
wherespeed > 90 partition by device_name interval(1d);
  • 查看流计算结果

注:本次适配没有修改原有前端页面,需要调用HTTP API 来创建设备配置。感兴趣的小伙伴可以完善一下,欢迎提交代码交流。


http://www.ppmy.cn/server/134786.html

相关文章

开源模型应用落地-Qwen2.5-7B-Instruct与vllm实现离线推理-CPU版本

一、前言 离线推理能够在模型训练完成后,特别是在处理大规模数据时,利用预先准备好的输入数据进行批量推理,从而显著提高计算效率和响应速度。通过离线推理,可以在不依赖实时计算的情况下,快速生成预测结果&#xff0c…

一分钟学会MATLAB-数值计算

在MATLAB中,数值计算是其核心功能之一,广泛应用于数学、工程和科学领域。MATLAB提供了丰富的工具和函数来处理各种数值计算问题。下面是一些入门级的数值计算示例及相应的代码。 1. 基本的数值计算 1.1. 线性方程组的求解 线性方程组的形式为 ( Ax b…

机器学习方向在算法优化上有哪些创新点?

以下是机器学习算法优化方面的一些创新点: 一、优化算法自身的改进 随机梯度下降(SGD)的变体 Adagrad 传统的随机梯度下降算法使用固定的学习率,而Adagrad根据每个参数的历史梯度信息自适应地调整学习率。对于稀疏数据,它可以为不同的参数分配不同的学习率,使得频繁出现…

教育技术的未来:Spring Boot在线教学平台

3系统分析 3.1可行性分析 通过对本信息化在线教学平台实行的目的初步调查和分析,提出可行性方案并对其一一进行论证。我们在这里主要从技术可行性、经济可行性、操作可行性等方面进行分析。 3.1.1技术可行性 本信息化在线教学平台采用Spring Boot框架,JA…

网络服务请求流程简单理解

网络流程: DNS负责将域名解析为IP地址,ALB可以在多个服务实例之间分配流量,APISIX作为API网关处理更细粒度的流量管理,Service在Kubernetes中为Pod提供稳定的访问入口,而Kubernetes则负责整个应用的部署、扩展和运维。…

uniapp uview 上传图片,数据以formData + File 形式传输

期望 后端期望前端给的传参为 formData 形式, 同时文件的数据类型为File 形式. 解决过程 将文件处理为 File 格式 uview 中的 upload 组件点击上传之后不是标准的 File 形式,点击上传单个文件之后的控制台信息如下: [{"url": "blob:http://localhost:8081/…

go多线程

1.仅加go 在一个golang编写的程序,主函数运行完毕后,程序就结束了 package mainimport ("fmt""time" )func main() {// 如果这样写go 要加在上面的函数,因为如果只单独加在下面的函数或者都加上,程序就会直接…

封装echarts组件,即插即用(附源码)

前言&#xff1a;最近一个项目刚收工&#xff0c;分享一个常用的封装echarts的组件。 一、直接上组件代码 <template><el-card class"echart-card" shadow"hover"><template v-slot:header><div class"card-header">&…