In this article, I will use the MQTT Protocol to simulate the process of data collection and reporting through the publish/subscribe model on an industrial IoT gateway. The guide also tells you how to configure transparent data transmission and Modbus RTU, Modbus TCP on serial ports, IO(digital input, relay output), convert data to JSON, transfer it via MQTT over the cellular network, which is used to remote monitor the field data and control the field devices via relay.
- MQTT Introduction
MQTT is a lightweight messaging protocol based on publish/subscribe model, specifically designed for IOT applications in low bandwidth and unstable network environments. It can provide real-time reliable messaging services for network-connected devices with minimal code. MQTT protocol is widely used in IOT, Mobile Internet, Smart Hardware, Internet of Vehicles, Smart Cities, Power, Oil, Energy, and other fields.
- Transparent Test
Before the formal configuration, we can start with a transparent test to ensure the network connection between the client and server is normal, and understand the basic network environment through the test. The steps are as follows:
- Enter the WEBUI of configuration, then click the Basic Setting, enable the “Data Collect” feature, and set the Collect Period, Report Period, and other related options as you wish.
data:image/s3,"s3://crabby-images/17408/1740843481b01c98226fb66ffa39cbafa55acd74" alt="MQTT-MODBUS IOT GATEWAY transparent data transmission"
Data Collect: Enable or Disable the data collection feature, this is the switch of the whole data collection function
Collect Period: Set the period of data acquired from slave devices.
Report Period: Set the Period of data report to the server.
Enable Cache: Enable or Disable history data cache feature.
Cache Path: Choose where the cache data is stored.
Send minute, hour, and day data: Set the minute data period as you wish.
(2)Click the Interface Setting, and change the COM Protocol to “Transparent”, the other options must be set the same as a slave device.
data:image/s3,"s3://crabby-images/b4b2a/b4b2a1f82bcb01f85d971f91927d43fd8fcf0559" alt="MQTT-MODBUS IOT GATEWAY 1 MQTT-MODBUS IOT GATEWAY 1"
(3)Click the Server Setting, Protocol select “TCP”, Encapsulation Type select “Transparent”, the “Server Address” and “Server Port” must be set the same as the TCP server. The Register Packet, Heartbeat Packet, and Heartbeat Interval can be set as you wish.
data:image/s3,"s3://crabby-images/95334/9533460ffd8d4883ee4399b928bba40c0a847927" alt="MQTT-MODBUS IOT GATEWAY 2 MQTT-MODBUS IOT GATEWAY 2"
(4)Open the serial port tool, and open the specific serial port, then you can send any characters to the server.
data:image/s3,"s3://crabby-images/c5292/c5292b969fdffbd016152c1d3733c483f0c4c299" alt="serial port tool 1"
Then the TCP server will receive the message from the client, and you can also send a message to the client.
data:image/s3,"s3://crabby-images/b5ef1/b5ef19e14ff66be44fbc23ef25b8d6a6cc548464" alt="serial port tool 2 serial port tool 2"
So far, the transparent test has been done, the data is being transmitted to each other, and then we can proceed next step.
- MQTT ClientConfiguration
- Data Collect ThroughModbus RTU
(1) Enter the WEBUI of configuration, and click Interface Setting, this time, I use an RS485 serial port to connect the router and PC, of course, you can choose RS232, and change the COM Protocol into “Modbus”, the other options must set the same as a slave device.
(2)Click Modbus Rules Setting, then add a new one. The Order, Device Name, and Factor Name can be set to whatever you want. The Device ID, Function Code, Start Address, and Count must be set the same as a slave device.
data:image/s3,"s3://crabby-images/a5f5d/a5f5d5b9a4690bad1d4aa54c31e018cb3cc816f0" alt="MQTT-MODBUS IOT GATEWAY4 MQTT-MODBUS IOT GATEWAY4"
ATTENTION: You need to select the corresponding interface according to the specific serial port.
(3)Click Server Setting, the specific configurations are as follows:
data:image/s3,"s3://crabby-images/d0fd4/d0fd416ffac5585fe959e7c7477ac69ca34d40ae" alt="MQTT-MODBUS IOT GATEWAY5"
Protocol: Select “MQTT”
Encapsulation Type: Select “JSON”
Server Address: Bivocom has a regular address “isodev.picp.net”(for testing only)
Server Port:1883
Heartbeat Interval: the interval between data publication and subscription
MQTT Public Topic: the topic you wanna publish in the MQTT client
Client ID: Set a unique ID as you wish
After setting these parameters, remember to click “Save&Apply”, then the Connection Status will change to “CONNECTED”.
(4) Here I use Modbus Slave to simulate the slave device, open the simulate tool, set the corresponding interface parameters of the client router, and then click connect. In this case, I set the value as “111”.
Open the Slave Definition, the Function code select “03” which means read the register’s data.
data:image/s3,"s3://crabby-images/18585/1858567eca5594f44efc623f900360561380aa45" alt="MQTT-MODBUS IOT GATEWAY7"
After setup, you can see the Real-time data collection accepts the value just set.
data:image/s3,"s3://crabby-images/0d4d2/0d4d2f0297c6ed58b32d10ab81807ee6ebda0771" alt="MQTT-MODBUS IOT GATEWAY8 MQTT-MODBUS IOT GATEWAY8"
(5)Open the MQTT.fx tool or other software can work as an MQTT client on a PC, The Broker Address must be the same as the Server Address you just set, and the Broker port is also 1883. Finally, click connect after setup.
data:image/s3,"s3://crabby-images/cb55f/cb55ffdea11ffa2a0db2c4d0be49acaf8f95094a" alt="MQTT-MODBUS IOT GATEWAY9"
Then subscribe to the public topic I just set in the client server which is “yes”. There will be the topic message from the MQTT Client.
data:image/s3,"s3://crabby-images/f0b98/f0b98e6bb5f9c7f732cd89b244a5d7d25acab7fb" alt="MQTT-MODBUS IOT GATEWAY10"
We can also see the communication between the slave device and the gateway.
data:image/s3,"s3://crabby-images/3c54b/3c54bcfeb1d1e27d10abaf0602509ef6c9f8e980" alt="MQTT-MODBUS IOT GATEWAY11 MQTT-MODBUS IOT GATEWAY11"
- Data Collect Through Modbus TCP
The setting is almost the same as the ModBus RTU protocol, the interface is changed into RJ45 instead of a ModBus serial port. The specific steps are as follows:
(1)Click Interface Setting, and enable the “TCP Server” option, The Server Address is the slave device’s IP address, COM Protocol select “Modbus-TCP”. The Server Port should be distinguished from the local TCP Server’s port, here I set as “9000”.
data:image/s3,"s3://crabby-images/c11c2/c11c2d01faf9384d2108e0822afe9c99c0087590" alt="MQTT-MODBUS IOT GATEWAY12 MQTT-MODBUS IOT GATEWAY12"
data:image/s3,"s3://crabby-images/b33da/b33da6cf300e15865491b2ca654f35135646b633" alt="MQTT-MODBUS IOT GATEWAY13 MQTT-MODBUS IOT GATEWAY13"
(2)Click Server Setting, the parameters are set as follows:
data:image/s3,"s3://crabby-images/54c72/54c728ee93c98a8a3070eace2dc31003f7cec2f9" alt="MQTT-MODBUS IOT GATEWAY14 MQTT-MODBUS IOT GATEWAY14"
Protocol: Select “TCP”
Encapsulation Type: Select either JSON or Transparent
Server Address: the same as TCP Server “192.168.1.161”
Server Port: the same as TCP Server “8080”
After setting these parameters, remember to click “Save&Apply”, then the Connection Status will change to “CONNECTED”.
(3)Add a new Modbus Rule for the TCP interface, click ModBus Rules Setting, and select the interface as “TCP”, the other parameters are the same as COM.
data:image/s3,"s3://crabby-images/fa08d/fa08d8f4838b3f5a52b8e6a3d6f987389d6516ec" alt="MQTT-MODBUS IOT GATEWAY15 MQTT-MODBUS IOT GATEWAY15"
data:image/s3,"s3://crabby-images/0bbeb/0bbeb6aee68b422ca3edb5c3c9fd2c75cec4518b" alt="MQTT-MODBUS IOT GATEWAY16 MQTT-MODBUS IOT GATEWAY16"
(4) Open the slave’s connection Setup, Connection selects “Modbus TCP/IP”, the IP address is the same as the TCP server. The slave’s port and TCP server’s port need to be distinguished, in order to ensure that a port is not occupied.
data:image/s3,"s3://crabby-images/067da/067dae10ffa34e674adaf510251f010f89edf4a7" alt="MQTT-MODBUS IOT GATEWAY17"
(5)After that, we can see the connection is established in the TCP Server.
data:image/s3,"s3://crabby-images/adf5e/adf5ea3532de0fd78b8f9af0e23fad991cacc853" alt="MQTT-MODBUS IOT GATEWAY18 MQTT-MODBUS IOT GATEWAY18"
The slave and TCP server start transmitting data.
data:image/s3,"s3://crabby-images/ac17f/ac17f5e0c5eb4e13c484923dc7096f41fb24ee57" alt="MQTT-MODBUS IOT GATEWAY19"
- IO Setting
- Relay Setting
- Click IO Setting, and add a new Relay Channel, the parameters are set as follows:
data:image/s3,"s3://crabby-images/7be98/7be9856a62963a0671d5c1fa73c0590a5ffedd23" alt="MQTT-MODBUS IOT GATEWAY20"
Device Name: The device name is set as you wish
Relay Channel: In relay interfaces, there are multiple channels available determined by a specific device
Factor Name: Corresponding report code of data collected
Reporting Center: data report center’s number
Relay Control: initial state of the relay, there are “open” and “close” two options
Once added, remember to click Save&Apply.
- Add an MQTT Subscribe Topic in the Server Setting, here I set “no”.
data:image/s3,"s3://crabby-images/2cbf1/2cbf1709111e1f0d8d1d93ad8d5c5638a9b5eaf3" alt="MQTT-MODBUS IOT GATEWAY21"
- Open MQTT.fx, and subscribe to the topic that is published in the MQTT Client, which will accept the initial state of relays.
data:image/s3,"s3://crabby-images/dc25d/dc25d324f8e3f7809b11cd8f7ab9d536a6eef46d" alt="MQTT-MODBUS IOT GATEWAY22 MQTT-MODBUS IOT GATEWAY22"
- RemoteControl Relay
- If you want to control the relay’s state, you should publish the Subscribe Topic just set, and then issue the corresponding command.
data:image/s3,"s3://crabby-images/cab66/cab665b15fb15ab99a509682a0b34950bf3a7712" alt="MQTT-MODBUS IOT GATEWAY23"
Then the gateway will respond with the status “OK”
data:image/s3,"s3://crabby-images/5ebb6/5ebb69ebe158a8e811582eecc0eefdcb64eed406" alt="MQTT-MODBUS IOT GATEWAY24 MQTT-MODBUS IOT GATEWAY24"
After a while, you’ll see the relay’s state has changed successfully.
data:image/s3,"s3://crabby-images/6127f/6127fedab6f8593dc04c59a4a05f2c0295d1e0c4" alt="MQTT-MODBUS IOT GATEWAY25"
- If you do not modify successfully, you should check whether the corresponding interface is configured, or check the command format. Because the control command is in JSON format, if your command is incorrect, it will not be executed.
data:image/s3,"s3://crabby-images/a8ddd/a8ddd8470d65aa83b875b04acb8c69f60b6b1a6e" alt="MQTT-MODBUS IOT GATEWAY26"
The gateway will respond like this:
data:image/s3,"s3://crabby-images/248f7/248f74ed83a112dce49c72a6a66ff999b5054c8f" alt="MQTT-MODBUS IOT GATEWAY27"
So before issuing the command, you have to change the corresponding control command into JSON format. This is very important.
You can try to issue different commands serval times to verify if the state of relays can be changed successfully.
- DI Setting
- Click IO Setting, you need to add a New DI Channel, the parameters are set as follows:
data:image/s3,"s3://crabby-images/1d7c8/1d7c857a5b8bebce146320e1f10a69cc24eb6645" alt="DI setting MQTT 1 DI setting MQTT 1"
The other configurations are the same as the Relay Setting. Once added, remember to click Save&Apply.
- Open MQTT.fx and subscribe to the public topic, then you can see the initial state of the DI port.
data:image/s3,"s3://crabby-images/a2a98/a2a988cc938511bc39843d9121927a456e90fbc9" alt="DI setting MQTT 2 DI setting MQTT 2"
(3) If you want to change the DI’s state, you just need to short-circuit the “DI” port and the “GND” port. Then you’ll see the state of DI change immediately. You can try serval times to verify that.
- RemoteTelemetry Function
- Remote Telemetry Through MQTT
If you want to remotely modify the report factor’s value of the slave device, you should issue corresponding instructions through the MQTT Client or TCP Client. The command is also in JSON format. The specific steps are as follows:
- Add Modbus Rules, the exact method is the same as before. Here I add two factors, “A” and “B”.Then click Save&Apply.
data:image/s3,"s3://crabby-images/412ac/412ac325787f3fde5d29725d022845aea2710d07" alt="telemetry mqtt1 telemetry mqtt1"
- Click Server Setting, the configuration is also the same as above.
data:image/s3,"s3://crabby-images/5bddc/5bddc09bec9fba51b81c9db9181bfe601623eafd" alt="telemetry mqtt2"
- Open Modbus Slave, and set initial values of two factors.
data:image/s3,"s3://crabby-images/9b309/9b3094b60d00fbf2d3038889c4062412ea697a66" alt="telemetry mqtt3 telemetry mqtt3"
data:image/s3,"s3://crabby-images/ab3a3/ab3a3d7ae5afbb82574e8d9e3fe9c1e885d125a7" alt="telemetry mqtt4 telemetry mqtt4"
- Open MQTT.fx, and subscribe to the specific topic, then you can see the initial values of A and B.
data:image/s3,"s3://crabby-images/924fc/924fc134d3c2d9dabe09a56e4908178f71db538f" alt="telemetry mqtt5"
- Publish the corresponding topic, and issue the command to modify the factor’s value, Pay attention to the command is also JSON format.
data:image/s3,"s3://crabby-images/34f4a/34f4ace5beaf07f5eab88b67a0ae50ba9f169560" alt="telemetry mqtt6"
Then the gateway will respond to the status “OK”.
data:image/s3,"s3://crabby-images/54d38/54d389db49c40204a7e9cde742d2d15e96989e8e" alt="telemetry mqtt7"
After a while, you’ll see the factor’s value has changed successfully.
data:image/s3,"s3://crabby-images/1315a/1315ab858915c6f5bd704155fc56099eddc200bd" alt="telemetry mqtt8 telemetry mqtt8"
- Remote Telemetry ThroughTCP
- Click Interface Setting, enable TCP Server, the configuration is the same as before, and click Save&Apply.
data:image/s3,"s3://crabby-images/d7f21/d7f216f481897f3b6866a952e60b6cbf42850ae7" alt="telemetry mqtt9"
- Click Server Setting, change the Protocol to “TCP”, the Server Address and Server Port are the same as TCP Server, and click Save&Apply.
Then the TCP Server will accept the initial values of A and B.
data:image/s3,"s3://crabby-images/38a39/38a39088eca3d615d0fea4c1309e409d0e7f317d" alt="telemetry mqtt11"
The WEBUI also can accept the data.
data:image/s3,"s3://crabby-images/9b7ff/9b7ff7a21c0d1f69058aa23ab9a5886c11d66120" alt="telemetry mqtt12 telemetry mqtt12"
- Issue the corresponding command to modify the factor’s values as you wish. If the command is correct, the server will respond “status”: “OK” immediately.
data:image/s3,"s3://crabby-images/f4e66/f4e66c2421975385de98b6c30f3cb8123006389c" alt="telemetry mqtt13 telemetry mqtt13"
After a while, you’ll see the factor’s value has changed successfully.
data:image/s3,"s3://crabby-images/87ef2/87ef2515b07d2bd712ebf44ac360b50fcadc1eee" alt="telemetry mqtt14 telemetry mqtt14"
1 Comment