How-To Guides
Integration Guides

Generic MQTT Over SSL Integration Guide (Mosquitto)

6min

Review the following guide for setting up an integration between Litmus Edge and an MQTT broker using Mosquitto and SSL authentication.

Mosquitto is a lightweight open source message broker that Implements MQTT versions 3.1.0, 3.1.1 and version 5.0.

Before You Begin

Step 1: Retrieve Contents of ca.crt File

You will need to retrieve the contents of the ca.crt file, so that you can add it to the CA Certificate parameter value in the connector you'll configure in Step 2.

To retrieve the contents of the ca.crt file:

  1. Go to the Ubuntu system.
  2. Open your Home directory using the Files app.
  3. Open the ca.crt file.
  4. If you see the message Could Not Display "ca.crt", click Cancel.
  5. Right-click the ca.crt file and select Open with Other Application.
  6. Select View All Applications.
  7. Select Text Editor and click Select.
  8. Copy the entire contents of the file.

Step 2: Add the Generic MQTT Over SSL Connector

Follow the steps to Add a Connector and select the MQTT - Generic over SSL provider.

Configure the following parameters.

  • Name: Enter a name for the connector.
  • Hostname: Since Mosquitto is running locally on your PC, enter your IP address.
  • Port: Confirm that the default value 8883 is entered.
  • CA Certificate: Paste or upload the ca.crt file you copied in Step 1.
  • Certificate (Optional): Upload the certificate.
  • Private key (Optional)
  • Client ID: Enter <username>-with-ssl.
  • Username (Optional)
  • Password (Optional)
  • QoS: Confirm that the default value 0 is entered. The Quality of Service (QoS) level is an agreement between the sender of a message and the receiver of a message that defines the guarantee of delivery for a specific message.
  • Parallel Publish Count: Confirm that the default value of 100 is entered. The number of messages being published simultaneously. Once the defined limit has been reached, subsequent messages are silently dropped.
  • Integration Topic: Enter test.
  • LWT topic: Enter lwtTopicName.
  • LWT payload: Enter Some LWT Payload.
  • 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.
  • LWT retained: Select this check box 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.

Step 3: Observe the Log File

To observe the log file:

  1. Return to the Ubuntu system.
  2. Open a Terminal window if none is open.
  3. Enter sudo tail -f /var/log/mosquitto/mosquitto.log and press ENTER to open the log file.
  4. View the incoming requests.

Step 4: Enable the Connector

After adding the connector, click the toggle in the connector tile to enable it.

Document image


If you see a Failed status, you can review the Connector Logs and relevant error messages.

Step 5: View the Connection in the Log File

To view the connection in the log file:

  1. Return to the Ubuntu system log file.
  2. Enter sudo tail -f /var/log/mosquitto/mosquitto.log. The log file shows the new connection.

You should see something like this:

1576338704: New connection from 192.168.1.15 on port 8883. 1576338704: New client connected from 192.168.1.15 as JohnSmith-with-SSL (p2, c1, k2, u'JohnSmith').