Generic MQTT Integration Guide (Mosquitto)
Review the following guide for setting up an integration between Litmus Edge and an MQTT broker using Mosquitto.
Mosquitto is a lightweight open source message broker that Implements MQTT versions 3.1.0, 3.1.1, and version 5.0.
- Configure Mosquitto so that anonymous users are allowed to access it.
To verify that Mosquitto is running in Windows, open up a command prompt and enter netstat -an. If Mosquitto is successfully running, you should be able to see your IP address and port 1883.
If you don't see port 1883 being used:
- Open Task Manager > Services and start/restart the Mosquitto server from there.
- Make sure the mosquitto.conf file is correctly configured so that Mosquitto can run on your system.
Follow the steps to Add a Connector and select the MQTT - Generic provider.
Configure the following parameters.
- Name: Enter a name for the connector.
- Hostname: Mosquitto is running locally on your PC, so enter your IP address. If needed, use the ipconfig command in the command prompt window and refer to the IPv4 Address.
- Port: Confirm that the default value 1883 is entered.
- Client ID: Enter 1.
- Username: Leave this field blank.
- Password: Leave this field blank.
- QoS: Make sure the default value 1 is selected.
- Parallel Publish Count: Confirm the default value 100 is entered. The number of messages being published simultaneously. Once the defined limit has been reached, subsequent messages are silently dropped. The default value is 100.
- Integration Topic: Enter mos_topic_1.
- LWT topic: The topic for MQTT's Last Will and Testament feature. You can leave this value blank.
- LWT payload: The payload for MQTT's Last Will and Testament feature. You can leave this value blank.
- LWT payload type: The payload type for MQTT's Last Will and Testament feature. The options are string and base64.
- LWT QoS: The Quality of Service value for MQTT's Last Will and Testament feature. The default value is 1.
- LWT retained: Select this checkbox to retain the value for MQTT's Last Will and Testament feature.
- Throttling limit: The maximum number of messages per second to be processed. The default value is zero, which means that there is no limit.
- Persistent storage: When enabled, this will cause messages to undergo a store-and-forward procedure. Messages will be stored within Litmus Edge when cloud providers are online.
- Queue Mode: Select the queue mode as lifo (last in first out) or fifo (first in first out). Selecting lifo means that the last data entry is processed first, and selecting fifo means the first data entry is processed first.
To add the outbound and inbound topics to the MQTT connector:
- Navigate to Integration.
- Click the MQTT - Generic connector tile.
- Click the Topics tab.
Click the Add a new subscription icon. The Data Integration dialog box appears.
- Configure the following parameters.
- Data Direction: Select Local to Remote - Outbound.
- Local Data Topic: Enter a name for the local data topic.
- Remote Data Topic: Confirm the topic where the data is pushed. This is the Integration Topic value for the connector.
- Enable: Select the toggle to enable the topic.
- Click OK to add the topic.
- Click the Add a new subscription icon again to add the inbound topic.
- Configure the following parameters.
- Data Direction: Select Remote to Local - Inbound.
- Local Data Topic: Enter integration.raw.Mos_topic_1.
- Remote Data Topic: Confirm the topic where the data is pushed. This is the Integration Topic value for the connector.
- Enable: Select the toggle to enable the topic.
- Click OK to add the topic.
After adding the connector, click the toggle in the connector tile to enable it.
If you see a Failed status, you can review the Connector Logs and relevant error messages.
To create the flow:
- In Litmus Edge, navigate to Flows Manager.
Click the Go To Flow Definition icon for a selected Flows Manager. The Flow canvas opens in a new browser tab.
From the flow canvas, drag the DataHub Subscribe node (DataConnector section), Inject node (Common section), and Debug node (Common section) to the canvas.
Connect the DataHub Subscribe and Inject nodes to the Debug node.
- Double click the DataHub Subscribe node. The Edit DataHub Subscribe Node dialog box appears.
- In the Topic field, enter integration.raw.Mos_topic_in.
- If needed, configure the DataHub Subscribe connection. See Configure Connector Nodes to learn more.
- Click Done.
- Double-click the Inject node. The Edit Inject Node dialog box appears.
- In the msg.payload field, select string.
- In the msg.topic field, enter integration.raw.Mos_topic_1.
- Enter test in the Name field, and then click Done.
- Click Deploy to save the flow.
- Open the command prompt window and go to the directory that stores Mosquitto files.
Enter mosquitto_pub.exe -t mos_topic_1 -m "Hello from Mosquitto", and then press ENTER.
- In the browser window that has the Litmus Edge flow canvas, expand the message window beneath the flow to view debug messages and click the Debug icon. Verify that Hello from mosquitto displays.