Формат данных для MQTT: различия между версиями

Материал из EWiki
Перейти к навигации Перейти к поиску
Новая страница: « === Формат Payload === ==== Бинарный формат (например, struct) ==== '''Формат: Фиксированная структура байтов.''' * 2 байта - битовый описатель. 0-2 версия 3-5 - формат данных (00 - binary, 01 - json) для данного пакета 00 6 бит - наличие времени 7-10 бит – int/float/string (null/bool(byte)/float64/(u)int8/(u)int1...»
 
Нет описания правки
 
(не показаны 3 промежуточные версии этого же участника)
Строка 1: Строка 1:
=== Фиксированный заголовок (1 байта) ===
Биты:


=== Формат Payload ===
0-2 - версия


==== Бинарный формат (например, struct) ====
3-5 - формат данных (0 - binary, 1 - json)
'''Формат: Фиксированная структура байтов.'''


* 2 байта - битовый описатель.
6-7 - резерв


0-2 версия
=== '''Binary формат''' ===


3-5 - формат данных (00 - binary, 01 - json) для данного пакета 00
==== Заголовок бинарного формата (1 байт) ====
0-3 - тип данных
{| class="wikitable"
|+
!ID
!Тип
!Реализация
|-
|0
|null
|
|-
|1
|bool
|byte
|-
|2
|float64
|
|-
|3
|int8
|
|-
|4
|uint8
|
|-
|5
|int16
|
|-
|6
|uint16
|
|-
|7
|int32
|
|-
|8
|uint32
|
|-
|9
|int64
|
|-
|10
|uint64
|
|-
|11
|string
|utf-8
|-
|12
|blob
|binary
|}


6 бит - наличие времени
4 - массив (не поддерживается для типов данных null и string)


7-10 бит – int/float/string
5-6 - тип метрики  (0 - не определено, 1 - счетчик (только растет), 2 - замер (может увеличиваться и уменьшаться))


(null/bool(byte)/float64/(u)int8/(u)int16/(u)int32/(u)int64/string(utf-8)/blob ) LE
7 - наличие метки времени


11 - array true/false (нельзя null, string)
==== Метка времени - опционально (8 байт) ====
В наносекундах


счетчик. замер
==== Полезная нагрузка ====
Используется little endian.


* Пример: 8 байт на время ms (uint64) - может отсутсвовать
=== '''JSON формат''' ===
*
<syntaxhighlight lang="js">
* Переменная часть для значения (данные).
{
 
"t":"2025-03-28T05:29:11.481Z", // время
'''JSON формат'''
"v": 42.13, // значение
 
"m": 2 // тип метрики (опционально)
* 2 байта - битовый описатель (01 - json)
}
*
</syntaxhighlight>
*
* данные Формат: {"t":<время>, "v":<значение>, "d":<описатель>}
 
Пример: {"t":"2025-03-28T05:29:24.413Z", "v":50.5, }
 
Для сложного значения: {"t":1617234567890, "v":[10,20,30], "d":"disk_iops"}

Текущая версия от 08:09, 28 марта 2025

Фиксированный заголовок (1 байта)

[править | править код]

Биты:

0-2 - версия

3-5 - формат данных (0 - binary, 1 - json)

6-7 - резерв

Binary формат

[править | править код]

Заголовок бинарного формата (1 байт)

[править | править код]

0-3 - тип данных

ID Тип Реализация
0 null
1 bool byte
2 float64
3 int8
4 uint8
5 int16
6 uint16
7 int32
8 uint32
9 int64
10 uint64
11 string utf-8
12 blob binary

4 - массив (не поддерживается для типов данных null и string)

5-6 - тип метрики (0 - не определено, 1 - счетчик (только растет), 2 - замер (может увеличиваться и уменьшаться))

7 - наличие метки времени

Метка времени - опционально (8 байт)

[править | править код]

В наносекундах

Полезная нагрузка

[править | править код]

Используется little endian.

{
 "t":"2025-03-28T05:29:11.481Z", // время
 "v": 42.13, // значение
 "m": 2 // тип метрики (опционально)
}