Пример mqtt_subscriber (Mosquitto)
Пример использования протокола MQTT в KasperskyOS.
В этом примере MQTT-издатель должен быть запущен в хостовой операционной системе, а MQTT-подписчик в KasperskyOS. Программа Subscriber
представляет собой реализацию MQTT-подписчика.
В результате успешного запуска и работы примера MQTT-подписчик, запущенный в KasperskyOS, выведет сообщение "Got message with topic: my/awesome/topic, payload: hello"
.
Пример также демонстрирует использование разных виртуальных файловых систем (далее VFS) в одном решении. В примере для доступа к функциям работы с файловой системой и функциям работы с сетью используются разные VFS:
- Для работы с сетью используется программа
VfsNet
. - Для работы с файловой системой используются программы
VfsRamfs
иVfsSdCardFs
.
Для сборки и запуска примера используется система CMake из состава KasperskyOS Community Edition.
Запуск Mosquitto
Для запуска этого примера MQTT брокер Mosquitto должен быть установлен и запущен в хостовой системе. Для установки и запуска Mosquitto выполните следующие команды:
$ sudo apt install mosquitto mosquitto-clients
$ sudo /etc/init.d/mosquitto start
Для запуска MQTT-издателя в хостовой системе выполните следующую команду:
$ mosquitto_pub -t "my/awesome/topic" -m "hello"
Поставляемые ресурсы
В пример входят следующие файлы конфигурации:
./resources/include/config.h.in
содержит описание бэкенда файловой системы, которая будет использоваться в решении:sdcard
илиramfs
.Для каждого бэкенда в решении также используется отдельная программа VFS:
VfsSdCardFs
илиVfsRamfs
соответственно.- Директории
./resources/ramfs/etc
и/resources/sdcard/etc
содержат файлы конфигурации для программVFS
,Dhcpcd
иNtpd
.
Файлы примера
Код примера и скрипты для сборки находятся по следующему пути:
/opt/KasperskyOS-Community-Edition-<version>/examples/mqtt_subscriber
Сборка и запуск примера
Чтобы запустить пример на QEMU, перейдите в директорию с примером, соберите пример и выполните следующие команды:
$ cd build/einit
# Перед выполнением следующей команды убедитесь, что путь к
# директории с исполняемым файлом qemu-system-aarch64 сохранен в
# переменной окружения PATH. В случае отсутствия
# добавьте его в переменную PATH.
$ qemu-system-aarch64 -m 2048 -machine vexpress-a15 -nographic -monitor none -sd sdcard0.img -kernel kos-qemu-image
Также см. "Сборка и запуск примеров".