Открытый проект клиента MQTT на Delphi. Продолжение

66c4601681f14974a2bdfc14e97e6059.png
Начало было здесь: Протокол MQTT и открытый проект клиента MQTT на Delphi

Проект клиента MQTT на Delphi дополнился приборной панелью для наблюдения за потоком информации из интернета вещей в реальном времени и генератором периодических публикаций для тестирования MQTT брокеров. Был принят формат JSON для передачи информации, поскольку он является стандартом для интернет-сервисов.
А также посмотрим что может нам предложить IBM Bluemix для организации удаленного наблюдения и управления вещами в интернете.


После того как в предыдущей версии клиента была реализована возможность принимать, посылать и подписываться на MQTT пакеты, наступила очередь реализовать генерацию потока сообщений для тестирования работы брокеров MQTT. Другой задачей стало определиться со структурой тела сообщений. Здесь в помощь был привлечен способ структурирования информации, применённый в сервисе IoTF IBM Bluemix. Даже если структурирование, применённое там и не идеальное есть основания некоторое время придерживаться таких правил, поскольку IBM вполне авторитетный бренд.
Структура в данном контексте это то, как в каждом пакете кодируется информация и в каком составе она передается. Нужно решить передаем ли по одной переменной или группами, если группами, то как отделять переменные друг от друга, как отличать переменные, метаданные и прочее, как сопоставлять переменные с их описанием или именами и нужно ли во всех случаях сопровождать переменные именами или достаточно индексов и т.д. Протокол MQTT никак не регламентирует данный вопрос за исключением того, что текстовые данные кодируются в формате UTF8, что в принципе тоже неплохо, ибо позволяет топики называть по-русски.
Интернет гиганты выбрали для решения вопроса структурирования формат JSON, хотя MQTT спокойно перенес бы и XML, и ASN.1 в какой-либо кодировке и другие форматы. JSON, кстати, имеет и несколько спецификаций сжатия, если есть претензии к избыточности текстового формата.
Итак, теперь наш клиент способен посылать пакеты содержащие текстовые данные в формате JSON и кодированные в UTF8. Для этого в нем есть закладка «Периодическая публикация». Публикация на сленге MQTT означает просто посылку пакета с данными предназначенными другим узлам сети IoT.
9c7729c0c8d340cfb10fde167131ed1c.png
На скриншоте каждой строчке в таблице соответствует определенное сообщение. Все сообщения в данном примере имеют одинаковый топик. Здесь политика такая — чем меньше разных топиков, тем меньше нагрузка на брокера по парсингу, поиску и сохранению этих топиков. Топики выбраны в таком формате в каком их примет сервис IoTF IBM Bluemix. В столбце Payload содержится тело сообщения. Оно представлено в формате JSON, но в нем для одной переменной допустимо применение спецификатора формата согласно правилам для функции Format языка Delphi. В данном случае применен спецификатор %g. На его место будет подставлено значение переменной, генерируемой по правилам, указанным в столбцах: Timeout (период посылки сообщения), Function (есть только выбор между случайной величиной и функцией синуса), Min, Max (минимальное и максимальное значение генерируемой величины), Period (период функции синуса, задаваемый в количестве отсчетов), Offs (смещение аргумента функции синуса, задаваемой количеством отсчётов). Столбцы QoS и Retain задают атрибуты MQTT пакета. Поле Enabled указывает будет ли это сообщение активизировано при нажатии кнопки «Стартовать». Кнопка «Стартовать» становится активной только после установления связи с брокером.
Важно! Сервис IoTF IBM Bluemix очень чувствителен к синтаксису и разрывает связь сразу же в случае если топик каким-то образом не подходит по формату.
В нижней части формы находятся логи: общий, лог отправленных сообщений публикации и лог принятых сообщений публикации. Логи можно очистить или запретить. Запрет логов ускоряет генерацию пакетов и прием пакетов.
7ffcf01fab134968890aa18ec224b676.png

Начинать надо с подписки на данные если на них не было сделано постоянной подписки в предыдущей сессии сеанса связи, иначе брокер ничего не пришлет.
В закладке «Подписка списком» нужно записать топики, которые мы хотим получать от брокера. В данном случае записан топик со значением которого будут посылаться сообщения генератором.
Если поле Subscribe помечено, то на топик будет осуществлена подписка после нажатия кнопки «Подписка». Если значение поля Subscribe не помечено, то будет выполнен отказ от подписки на данный топик при нажатии на кнопку «Подписка». Опять же операция подписка доступна только после установления связи с брокером.
Еще до подписки можно записать в таблицу визуальных компонентов те переменные, которые мы хотим наблюдать в реальном времени. Для этого надо нажать кнопку «Таблица».
a130e59d7569444cae872813c6f5d1c2.png

Столбец «Variable Name» содержит такое же имя переменной (ключ в терминологии JSON) какое записано в сообщении в формате JSON. Поле «Variable Caption» содержит название переменной, отображаемое на визуальном компоненте. Столбец «Widget Class» задает тип визуального компонента. Здесь можно выбрать какую-либо шкалу, LCD/LED стиля надпись или график.
Закончив редактирование таблицы нажимаем кнопку Widgets и расставляем визуальные компоненты в форме. Поначалу все компоненты будут находится в стопке в левом верхнем углу. Надо перетащить и расположить их на форме в желаемой конфигурации. Расположение компонентов запоминается и воспроизводится после следующего открытия формы. Стиль докинга компонентов повторяет стиль IDE RAD Studio или MS Visual Studio.
0be56c5674824b61b08121e9c6f1da1c.png

Если связь с брокером установлена и выполнена подписка, то в случае прихода сообщений с соответствующими переменными в окне визуальных компонентов сразу отразятся их значения.

Все настройки и логи программа сохраняет в JSON файлах на диске, которые можно редактировать вручную.
В репозитарии лежит версия программы с подготовленной и сохраненной в JSON файлах конфигурацией готовой к тестированию с применением брокера Mosquitto включенного локально.
Сам брокер готовый к запуску находится в репозитарии в архиве Mosquitto_broker_projs.zip в директории Mosquitto_1_4_5_bin. Запускать надо файл Run_mosquitto.cmd.


В программе применен сторонний JSON парсер из проекта https://github.com/hgourvest/superobject Несмотря на то, что в RAD Studio XE8 есть встроенный JSON парсер superobject показался интереснее и мощнее с точки зрения возможностей. Программа клиента MQTT при поступлении сообщений производит парсинг тела сообщения и выделяет в нем отдельные пары ключ-значение. Если встречается массив, то он игнорируется поскольку объекты в массиве не имеют имен, и нет механизма (в данной программе) связать их с какой-либо именованной переменной в клиенте. Остальные именованные объекты просматриваются вглубь рекурсивно пока не будут извлечены все пары ключ-значение. Ключ будет являться именем переменной, значения программа будет пытаться привести к числу с плавающей точкой, если не удается, то число приравнивается нулю.
Это приложение второе из двух практических приложений, предлагаемых IBM для IoT. Первое — Internet of Things Foundation рассматривалось в предыдущей статье. Есть в каталоге IBM еще несколько демонстрационных приложений для IoT, но они требуют развертывания и запуска на сервере пользовательского кода, что автоматически включает счетчик оплаты.
Но вернемся к IoT Real-Time Insights. Заходим в свой аккаунт. Как всегда, выбираем регион US South. Жмем в верхнем меню Catalog. Спускаемся в самый низ попутно наблюдая массу разных сервисов и приложений у IBM. Видим:
ad8a87160a0a4e17bf8062876163bdf3.png

Нажимаем на IoT Real-Time Insights. Это приложение позволяет только наблюдать, управлять напрямую устройствами из него не получится, если только устройства не обладают другими каналами связи помимо MQTT.
При создании поле App: оставляем Leave unbound. Дополнительные приложения не создаем, поскольку за них IBM сразу начинает считать деньги. Поле Plan: оставляем Lite. Так нам все будет бесплатно.
f65556530e2944bd893c4e31a632512d.png

До того у нас должен быть уже создан и активизирован сервис Internet of Things Foundation, в нем уже создано хотя бы одно устройство от имени которого будет посылать пакеты наш клиент MQTT. Это было описано в предыдущей статье.
e951196d6ae4492498df5c48b3a5c662.png

На домашней странице приложения IoT Real-Time Insights сразу начинаем с подключения источника данных, и это будет созданный ранее нами сервис Internet of Things Foundation. Мы должны знать его кодовое название (Organization ID), API Key и Authentification Token. Если не знаем, то вернуться в Internet of Things Foundation и создать, то чего не знаем.
После подключения на закладке Devices должны отображаться все зарегистрированные нами устройства. В данном случае есть только одно.
7afada8096b54059834ea1d8656fea82.png

Затем надо настроить схемы сообщений. Нажать на Manage Schemas и на плюсик Add new message schema. Это как можно понять настройка расшифровки сообщений от устройства.
8b3987b4551c41c692444bfc7f0db600.png

Вот пример такой настройки для переменных T, L1, L2, L3.
54e2c849d61c45cbb32ecbb1648459b2.png

Переменная L1, например, при редактировании представлялась таким окном.
30e7a6acfcf94385829711724cf6aba2.png

Настроив схемы можно настроить аналитику. Т.е. по сути правила для формирования отправки сообщений внешним приёмникам сообщений. Самое доступное это отправить email.
Вот так выглядит правило отправки email в случае превышения переменной T значения 24:
f49416a637a64043b2f3da7c7e185c48.png

А вот такое сообщение на email приходит:
ce9edc40be624455940e1be17eb07c0a.png

Но центральным пунктом приложения являются приборные панели. Панелей может быть много. Приборные панели состоят из визуальных компонентов отображающих значения переменных, созданных в закладке Manage Schemas в реальном времени. На скриншоте ниже показан пример приборной панели для отображения 4-х переменных: T, L1, L2, L3. Пакеты со значениями переменных генерировались нашим клиентом MQTT. Переменная T генерировалось как случайное число, L1, L2, L3 как функции синуса.
902072b7216042d0b1f4208cfd2bb0d7.png


Пока приложение очень сырое. Окна и диалоги открываются с большими задержками. Построитель приборных панелей ограничен в функциональности, для простых перемещений или изменений размеров надо проходить несколько диалогов. Сами компоненты панелей не имеют никаких редактируемых свойств. Это же относится и к графикам. Графики не имеют истории, и очищаются при малейшем изменении размеров окна. Email-ы приходят не стабильно, и могут подолгу задерживаться.
Но все же это бесплатный сервис, доступный здесь и сейчас и если устройство способно публиковать сообщения в подходящем JSON формате, то стоит иметь в виду такое приложение от IBM.

Проект клиента MQTT находится по прежнему на старом месте: https://github.com/Indemsys/Delphi_MQTT_mosquitto

© Geektimes