####### MQTT/MQTT-SN (MQ Telemetry Transport for sensors)
- MQTT ** Is an machine-to-machine TCP/IP connectivity protocol ** MQTT stands for MQ Telemetry Transport. It is a publish/subscribe, extremely simple and lightweight messaging protocol, designed for constrained devices and low-bandwidth, high-latency or unreliable networks.
- MQTT-SN ** For non-TCP/IP protocol
- MQTT broker ** The central communication point in charge of dispaching all the messages b/w senders and the rightful receivers. ** The topic is the routing information for the broker
- Spring has only support for MQTT
- http://dev.lelylan.com/api#api-physical-mqtt
- Eclipse Paho client has only C based library for MQTT-SN. Need to write our own Java code using JNI to support MQTT-SN
- Raspberry Pi is a low cost, credit-card sized computer that plugs into the monitor or TV, and uses standard keyboard and mouse.
- Example: End to End MQTT communication example: http://lelylan.github.io/lab-projects/raspberry-pi-light/
- Installation ** Can use SD Formatter 4.0 to format the SD and copy the NOOBS Raspberry pi bootable content **
- Useful Commands ** file raspbian-jessie.img : Displays the file information in MacOS ** hostname -I -> to display the pi ipAddress ** startx to start the GUI ** ping raspberrypi.local ** ssh [email protected] ** pi-finder: Is an utility used to find the Raspberry Pi IP address ** pi-filler: Is an utility to mount the img to SD Card ** hdmi_force_hotplug=1 add it in config file, SD card to force HDMI display ** Find the Pi ip : https://github.com/thoqbk/pi-oi ** arp -a
- Troubleshoot ** Make sure SD card is not locked ** After power plug is connected, Green light should blink **
- Open source Linux distribution for embedded devices(typically wireless routers)
- QEMU is a generic and open source machine emulator and virtualizer.
- Raspberry Pi Emulator ** XCode ** HomeBrew ** Install QEMU *** brew install qemu --env=std ** RPi disk image ** Linux kernel image compiled for ARM ** command : qemu-system-arm -cpu arm1176 -m 256 -M versatilepb -no-reboot -serial stdio -append "root=/dev/sda2 rootfstype=ext4 rw init=/bin/bash console=ttyAMA0,115200" -kernel kernel-qemu -hda 2013-07-26-wheezy-raspbian.img qemu-system-arm -cpu arm1176 -m 256 -M versatilepb -no-reboot -serial stdio -append "root=/dev/sda2 rootfstype=ext4 rw init=/bin/bash console=ttyAMA0,115200" -kernel kernel-qemu-4.1.13-jessie -hda raspbian-jessie.img
- To emulate the Raspberry Pi on OS X
- Link: https://sourceforge.net/projects/raspberrypiemulator/?source=directory
- How to Use ** Get the Raspberrypi from https://sourceforge.net/projects/raspberrypiemulator/ ** Run /raspberry-pi-emulator-1.6.1/Mac OS X/Raspberry Pi Emulator.app/Contents/MacOS/Raspberry Pi.sh (run ./Raspberry\ Pi.sh) ** Might take time as it needs to download the Raspbain OS image and kernal
- Useful commands/tools ** hostname -I -> to display the pi ipAddress ** ping raspberrypi.local ** ssh [email protected] ** pi-finder: Is an utility used to find the Raspberry Pi IP address ** pi-filler: Is an utility to mount the img to SD Card ** hdmi_force_hotplug=1 add it in config file, SD card to force HDMI display ** Find the Pi ip : https://github.com/thoqbk/pi-oi ** arp -a **
- AllJoyn is a collaborative open-source software framework that makes it easy for developers to write applications that can discover nearby devices, and communicate with each other directly regardless of brands, categories, transports, and OSes without the need of the cloud.
- AllJoyn framework: it serves as the glue to allow devices from different companies, running on different operating systems, written with different language bindings to all speak together, and just work
- common services and interfaces that solves a specific use case, such as onboarding a new device for the first time, sending notifications, and controlling a device
- AllJoyn App: An application that uses the AllJoyn framework. Apps use either the AllJoyn Core APIs or the AllJoyn Service Frameworks API. Apps can either use the Standard Core or Thin Core implementations.
- AllJoyn-enabled device: An entity which has an AllJoyn application installed to send or receive notifications using the Notification service framework interface
- Client (Producer) ** Install the Raspberry Pi Image ** Install the OpenWRT on Raspberry Pi image ** Emulate the Raspberry Pi in Mac OS ** Install the Client specific capabilities on Raspberry Pi (May be like Java client to run)
- Broker ** Install the MQTT Broker on Mac OS **
- Client (Consumer) (Subcribers) ** Could be any device like Raspberry Pi or Mobile or desktop
-
DONE -- As a Dev I want to see a simple Spring application to simulate the Publisher and Subscriber communication
-
DONE -- As a Dev I want to see running client in the Raspberry Pi emulator, which publishes the info on a topic
-
DONE -- As a Dev I want to see running client in the Raspberry Pi emulator which subscribe and consumes the info on a topic
-
DONE -- As a Dev I want to see running client on Mac OS as a Subscriber to get the info published by the Raspberry Pi client
-
DONE -- As a Dev I want to see the communication b/w the Bridge and the IoT platform.
-
As a Dev, I want to understand the code written for Rules -- Rule, Trigger Channel, Choose Trigger, Action Channel, Choose Action -- Need an example with explanation ? -- Where Do I see list of defined Rules
-
As a Dev, I want to all the possible Configurations for MQTT clients
-
As a Dev, I want to PoC Android app with MQTT Client (Produce and Consume)
-
As a Dev, I want to implement few "Spring Integration Flows" so we can use them properly
-
As a Dev I want to have JSON Message Converter mechanism to handle after received in the MQTT client
-
As a Dev, I want to see required config / logic to message handled guarantee
-
As a Dev, I want to basic classes, interfaces in place to produce and consume the Services
-
As a Dev, I want to see Generic Consumer for all Topics ? is this make sense (PoC)
-
As a Dev, understand the Parallel message processing , Best solution to implement it
-
As a Dev, I want to see Best Messaging format for MQTT Protocol
-
As a Dev, I want to Know the Max Size of Message can send across
-
As a Dev, I want to understand the QoS , so I can implement the message processed guarantee.
-
As a Dev, I want to understand best practices to implement the MQTT clients, generic, multiple oe combination ?
-
As a Dev, Understand Can we define multiple clients per Topic
-
As a Dev, I want to see Architecture diagram , message flow and message processing
-
As a Dev, I want to Understand on Replication, Fault tolerance, HA and Scalability from Broker point of view
- Channel: A medium through which a message is transmitted to its intended audience.
- pipes-and-filters: The "filters" represent any component that is capable of producing and/or consuming messages, and the "pipes" transport the messages between filters
- Why type of Channel adapters are available ** LoggersChannelAdapter ** InboundChannelAdapter **
- Important Classes and Interfaces ** Message(header, Payload) ** MessageChannel(PollableChannel, SubscribableChannel) *** A Message Channel represents the "pipe" of a pipes-and-filters architecture. *** Producers send Messages to a channel *** Point-to-Point **** at most one consumer can receive each Message sent to the channel *** Publish/Subscribe **** will attempt to broadcast each Message to all of its subscribers *** Both give flexibility to configure how many consumers will ultimately receive each Message *** should the channel buffer messages ? *** Pollable Channels are capable of buffering Messages within a queue ** MessageHandler ** Message Channel Implementations
- Message Converters/Transformations ** Convert from one message format to other, example: XML to String ** Also responsible for add, remove the header values
- Message Endpoints ** A Message Endpoint represents the "filter" of a pipes-and-filters architecture ** A Message Endpoint handles the Messages ** A Message Endpoint mapped to the Message Channel
- Message Router ** A Message Router is responsible for deciding what channel or channels should receive the Message next (if any). ** A Message Router is often used as a dynamic alternative to a statically configured output channel on a Service Activator or other endpoint capable of sending reply Messages **
- Splitter ** responsibility is to accept a Message from its input channel, split that Message into multiple Messages, and then send each of those to its output channel.
- Aggregator ** opposite of Splitter
- Service Activator ** A Service Activator is a generic endpoint for connecting a service instance to the messaging system
- Channel Adapter ** is an endpoint that connects a Message Channel to some other system or transport **
- http://docs.spring.io/spring-integration/docs/4.3.0.RELEASE/reference/html/mqtt.html
- https://github.com/spring-projects/spring-integration-samples/tree/master/basic/mqtt
- https://github.com/andypiper/spring-int-mqtt
- Open source MQTT Broker
- https://github.com/mqtt/mqtt.github.io/wiki/Server%20support
- Decisions to take ** One or more clients per Topic ** Async physical flow ** Message contract *** Format/Structure ?? Example: Device info ? *** Eg: {deviceId:, Properties: {[id: , value: expected: , pending: ],[]}} ** Generic MQTT client to handle all the message and distribute to the threads to process them ** Separate MQTT client per Topic ** Understand on Replication, Fault tolerance, HA and Scalability from Broker point of view
- References ** https://github.com/lelylan/lelylan/ ** http://dev.lelylan.com/#overview-tutorials ** http://lelylan.github.io/devices-dashboard-ng/index.html#/login ** https://medium.com/@lelylan/how-to-build-an-high-availability-mqtt-cluster-for-the-internet-of-things-8011a06bd000#.g2w5mtnaj
- Device Topic : device/deviceId
- Backend Topic : device/deviceId
- Device Properties : ** Value, expected and pending helps in Async communication ** Event helps in performing the action *** Example: Topic: device/DeviceId, payload property 'Event: update'
- Async Communication: Based on Device Properties, Device or App send the Appropriate status to update the system ? ** Example: *** Mobile -> turn on light -> Publish -> (Msg Payload with Event as 'update' and Properties {value:off,Expected:on, pending:true })
- MQTT Channel Adapter with Configuration like Topic(device/activation) and MessageConverter(JSON?) => Pub/Sub Message Channel => Message Handler => Consume CIoT Platform
- Topic Name
- Channel Type (Point-to-Point/Pub-Sub)
- Client need Acknowledgement back success/failure?
- Service call to backend
- Async physical flow
- Broker delivers the message to one of the topic subscriber client
- Parse the message (structure will be know based on Topic)
- Process the message ** Delegate to the backend service layer (internally it performs whatever needs to be) **
- Finally, depend on the topic and response from service layer, produce the message by certain Topic
- Prepare the message
- Execute the Producer MQTT client to send the message to the topic
- Broker will deliver to right subscriber
- Add/Kill the MQTT publisher or consumer on the fly at runtime
- What will be the message exchange format (JSON, YAML, XML)
- How can we effectively make use of Spring integration flows ?
- How many MQTT clients required at any given point of time to handle the message
- How to make sure we don't loose the messages and handled guranteed ? (Quality of Service) for every message
- Make sure parallel message streaming or handle async without compromising on the performance and message lost ?
- Deployment Model for MQTT Client in backend Platform ? ** Should be just a seperate threads(multiple clients) to process messages ** Could be a seperate module deployed in platform so that modular and independent?
- http://iot.eclipse.org/
- https://eclipse.org/kura/
- https://eclipse.org/smarthome/
- http://www.eclipse.org/paho/
|---| |Raspberry Pi|MQTT|MQTT-SN|MQTT Broker|AllJoyn|OpenWRT|QEMU|Mosquitto|XMPP|Spring Integration MQTT| |MQTT Client|IoT|CIoT Platform|Mongo DB|Emulator|