# Using MQTT with Node-RED
In the realm of IIoT (Industrial Internet of Things), effective communication between devices is crucial. One protocol that has gained significant popularity for its lightweight and scalable nature is MQTT (Message Queuing Telemetry Transport). This guide explains MQTT, its relevance in IIoT, and walks you through connecting a broker HiveMQ with Node-RED in FlowFuse.
# Understanding MQTT
MQTT, with development starting in 1999, is a publish-subscribe-based messaging protocol designed for efficient communication between IoT devices. It operates on top of TCP/IP, like HTTP, providing a lightweight approach to messaging. MQTT follows a client-server model, where devices (clients) publish messages to a central server called the broker. Other clients interested in receiving those messages subscribe to specific topics on the broker.
# Advantages of MQTT in IIoT
MQTT has become a preferred choice for IoT and industrial IoT applications due to several reasons:
- Low Overhead: MQTT uses small packet sizes, minimizing bandwidth consumption and reducing network traffic, suitable for low-power devices and networks.
- Reliability: MQTT incorporates Quality of Service (QoS) mechanisms for message delivery, ideal for applications requiring reliable data transmission.
- Asynchronous Communication: MQTT enables asynchronous communication, allowing devices to operate independently, reducing latency and increasing system responsiveness.
# Sending Messages to an MQTT Broker with Node-RED
Using a Cloud MQTT broker provided by HiveMQ, we'll host and manage the Node-RED instance in FlowFuse. The MQTT nodes are pre-installed as "Core Nodes" in Node-RED.
- Drag in the "Inject" node and the "MQTT out" node, connecting the Inject node's output to the MQTT out node.
- Configure the MQTT node to connect to the broker, using the username, password, and server details from HiveMQ.
- Save the config, deploy the changes, and ensure the MQTT node status is green, indicating successful connection and configuration.
After saving the config, and deploying the changes, the flow should tell display a green status bubble under the MQTT node which tells you it's connected and configured properly.
# Receiving Messages from an MQTT Broker with Node-RED
- Drag in the "mqtt in" node and connect it to the "Debug" node.
- Open the MQTT in node, select the configured server, and ensure the topic matches the previous selection.
- Deploy the flow, and the Debug node should display received messages.
When deployed you should again see the status bubble turn green, and have a timestamp appear in the sidebar every second!