你问的是两个非常不同的事情。
1) 通过正确映射网关传入消息,您可以一次传输更多键值对。我想您正在使用 MQTT 协议。此协议的默认映射在 /etc/tb-gateway/conf/mqtt-config.json 中指定。此文件指定如何将来自代理的传入 MQTT 消息转换为 ThingsBoard 键值格式,然后再发送到 ThingsBoard 的服务器实例。
要从传感器映射多个读数,您可以执行以下操作:
{
"brokers": [
{
"host": "localhost",
"port": 1883,
"ssl": false,
"retryInterval": 5000,
"credentials": {
"type": "anonymous"
},
"mapping": [
{
"topicFilter": "WeatherSensors",
"converter": {
"type": "json",
"filterExpression": "",
"deviceNameJsonExpression": "${$.WeatherStationName}",
"timeout": 120000,
"timeseries": [
{
"type": "double",
"key": "temperature",
"value": "${$.temperature}"
},
{
"type": "double",
"key": "humidity",
"value": "${$.humidity}"
}
]
}
}
]
}
]
}
这样,如果您向主题WeatherSensors 发送类似{"WeatherStationName":"test", "temperature":25, "humidity":40} 的消息,您将在名为“test”的设备中看到ThingsBoard 服务器中的两个键值对。
2) 访问存储在内部 ThingsBoard 服务器中的数据的最佳方式是通过 REST API,这样您就可以使用相同的代码查询任何 ThingsBoard 实例,而不管使用的技术如何数据库(Cassandra、PostgreSQL 等)。您可以在 repo 中找到 Python 示例。
另一种方法是对数据库使用特定的查询语言,例如用于 PostgreSQL 的 SQL 或用于 Cassandra 的 CQL。