22 MQTT
Introduction
MQTT (short for MQ Telemetry Transport) is an open OASIS and ISO standard (ISO/IEC PRF 20922) lightweight, publish-subscribe network protocol that transports messages between devices. The protocol usually runs over TCP/IP, although its variant, MQTT-SN, is used over other transports such as UDP or Bluetooth. It is designed for connections with remote locations where a small code footprint is required or the network bandwidth is limited.
The broker acts as a post office, MQTT doesn’t use the address of the intended recipient but uses the subject line called “Topic”, and anyone who wants a copy of that message will subscribe to that topic. Multiple clients can receive the message from a single broker (one-to-many capability). Similarly, multiple publishers can publish topics to a single subscriber (many to one).
Each client can both produce and receive data by both publishing and subscribing, i.e. the devices can publish sensor data and still be able to receive the configuration information or control commands. This helps in both sharing data and managing and controlling devices.
With MQTT broker architecture the devices and applications become decoupled and more secure. MQTT might use Transport Layer Security (TLS) encryption with a user name, password-protected connections, and optional certifications that require clients to provide a certificate file that matches the server’s. The clients are unaware of each other's IP address.
The broker can store the data in the form of retained messages so that new subscribers to the topic can get the last value straight away.
The main advantages of an MQTT broker are:
- Eliminates vulnerable and insecure client connections
- Can easily scale from a single device to thousands
- Manages and tracks all client connection states, including security credentials and certificates
- Reduced network strain without compromising the security (cellular or satellite network)
Each connection to the broker can specify a quality of service measure. These are classified in increasing order of overhead:
- At most once - the message is sent only once and the client and broker take no additional steps to acknowledge delivery (fire and forget).
-
At least once - the message is re-tried by the sender multiple times until acknowledgement is received (acknowledged delivery).
-
Exactly once - the sender and receiver engage in a two-level handshake to ensure only one copy of the message is received (assured delivery).
Using WCC Lite as an MQTT Client
MQTT serves as an alternative for protocols conforming to IEC standards, for example, to send data to a cloud infrastructure that supports MQTT instead of IEC-60870-5-104.
WCC Lite supports MQTT messaging compatible with MQTT v3.1 standard (starting from version v1.4.0). Such messaging is possible via mapping of Redis and MQTT data therefore data can be transmitted from any protocol that is supported by WCC Lite.
All standard functions, except for data encryption, are supported. Encrypted messages are not supported yet, therefore to ensure security a user would have to use a VPN service. A user can choose from three different Quality of Service levels, select if messages are to be retained, authenticate users and optionally send Last Will messages.
To configure WCC Lite a user can fill in the needed parameters in Excel configuration. These parameters are shown in the two tables below.
Table. MQTT parameters for the Devices tab
Parameter |
Type |
Description |
Required |
Default value (when not specified) |
Range |
|
Min |
Max |
|||||
name |
string |
User-friendly device name |
Yes | |||
device_alias |
string |
Device alias to be used in the configuration |
Yes | |||
enable | boolean |
Enabling/disabling of a device |
No | 0 | 0 | 1 |
protocol |
string |
Selection of protocol |
Yes | MQTT | ||
ip |
string |
MQTT broker IP address/Domain name selection |
Yes | |||
port | integer |
MQTT broker port selection |
No | 1883 | ||
enable_threshold | boolean |
A parameter to determine if identical values should not be sent multiple times in a row. |
No | 1 | 0 | 1 |
mqtt_qos | integer |
MQTT Quality of Service for the message as in standard |
No | 0 | 0 | 2 |
mqtt_retain | boolean |
Selecting if the MQTT broker should retain the last received messages |
No | 0 | 0 | 1 |
username |
string |
MQTT user name |
Yes | |||
password |
string |
MQTT user password | Yes | |||
auth |
string |
Selecting if TLS should be used | Yes |
none, password, tls |
||
ca_certificate |
string |
Certificate authority file for TLS connection |
Yes (If auth=tls) |
|||
client_certificate |
string |
Client certificate file for TLS connection |
Yes (If auth=tls) |
|||
client_key |
string |
The private key that corresponds to the client certificate for TLS connection |
Yes (If auth=tls) |
|||
use_last_will | boolean |
Selecting if MQTT should use the Last Will and Testament functionality (Default: False) |
No | 0 | 0 | 1 |
last_will_topic |
string |
Topic to which an MQTT message would be sent if the device abruptly disconnected the message broker |
Yes (If use_last_will=True) |
|||
last_will_message |
string |
Message to be sent over MQTT if the device abruptly disconnected message broker |
No | |||
last_will_qos |
integer |
MQTT Quality of Service selection as in standard |
No | 0 | 0 | 2 |
last_will_retain |
boolean |
Selecting if the MQTT broker should retain the last will message |
No | 0 | 0 | 1 |
client_id |
string |
User-friendly name for client ID |
No |
To map the signal to send through the MQTT client, it should have its device_alias and signal_alias mapped to source_device_alias and source_signal_alias respectively.
Table. MQTT parameters for the Signals tab
Parameter |
Type |
Description |
Required |
Default value (when not specified) |
Range |
|
Min |
Max |
|||||
signal_name | string |
User-friendly signal name |
Yes |
|
|
|
device_alias | string |
Device alias from a Devices tab |
Yes | |||
signal_alias | string |
Unique signal name to be used |
Yes | |||
source_device_alias | string |
device_alias of a source device |
Yes | |||
source_signal_alias | string |
signal_alias of a source signal |
Yes | |||
enable | boolean |
Enabling/disabling of an individual signal |
No | 1 | 0 | 1 |
log | integer |
Allow signal to be logged. Log signal with 1 and no logging with 0. |
No | 0 |
|
|
topic | string |
Topic name to override the value built by default |
No | |||
periodic_update_ms | integer |
Signal value is published periodically according to the value set. |
No | - | - | - |
MQTT data format
The format of a MQTT message is a bit different than Redis messages. Redis messages are supported as CSV strings: value, timestamp, flags (where value can be float, integer or nan; timestamp - Unix timestamp in milliseconds; flags contain additional information about a measurement). MQTT messages are supported as value, timestamp, and quality (where value can be float, integer or nan; timestamp - Unix timestamp in milliseconds; quality shows if a value is to be considered valid). Quality parts of a string are always equal to 1 except for Redis messages containing invalid (IV), non-topic (NT) and/or overflow (OV) flags.
As mentioned, the MQTT client acts as an adapter between Redis and MQTT, therefore data from the topic in Redis is written to a topic in MQTT. Therefore mqtt-client has to know the mapping table before starting. This table is saved at /etc/elseta-mqtt.json. Every Redis topic name is constructed as tag/[device_alias]/[signal_alias]/[direction]. Prefix tag/ is always used before the rest of the argument. device_alias
and signal_alias
represent columns in Excel configuration. Direction can have one of four possible values - rout, out, in, rin; all of which depend on the direction data is sent or acquired protocol-wise. The same Redis topic structure is preserved in MQTT by default making it easier to find matching signals, however, as no recalculation is done by MQTT and only PUBLISH messages are now supported, only Redis signals within direction have their MQTT mappings.
A user can create and select his topic name in Excel configuration, in the topic column. As no recalculation is done by MQTT and only PUBLISH messages are now supported, only Redis signals within in direction have their MQTT mappings.
Debugging a MQTT protocol
If the configuration for MQTT is set up, a handler for the protocol will start automatically. If the configuration is missing parameters or contains errors, the protocol will not start. It is done intentionally to decrease unnecessary memory usage.
MQTT Client command line debugging options
- Step 1: Service must be stopped by entering the following command into the wcclite:
/etc/init.d/mqtt-client stop - Step 2: After the service is stopped it must be started with the preferred configuration file (JSON files found in the /etc/ folder) and a debug level 7: mqtt-client -c /etc/mqtt-client/mqtt-client.json -d7 Additional output forming options described in the table below.
- Step 3: Once the problem is diagnosed normal operations can be resumed with the following command: /etc/init.d/mqtt-client start
-h [ –help ] Display help information
-c [ –config ] Configuration file location (default - /etc/elseta-mqtt.conf)
-V [ –version ] Show version
-d<debug level> [ –debug ] Set debugging level
-r [ –redis ] Show REDIS output
If the MQTT Client does not work properly (e.g. no communication between devices, data is corrupted, etc.), a user can launch a debug session from the command line interface and find out why the link is not functioning properly.
To launch a debugging session, a user should stop mqtt-client
process and run mqtt-client
command with respective flags as was shown above.