Jump to content

Modbus and Bluetooth data sending to Node-RED: Difference between revisions

 
(82 intermediate revisions by the same user not shown)
Line 3: Line 3:
<span style="color: red;">The information in this page is updated in accordance with the <span style="color: #0054A6;"><b>RUTXXX_R_00_07_03</b></span> firmware version.</span>
<span style="color: red;">The information in this page is updated in accordance with the <span style="color: #0054A6;"><b>RUTXXX_R_00_07_03</b></span> firmware version.</span>


Node-RED is a flow-based programming tool developed by IBM Emerging Technology and written in Node.js. It provides a browser-based editor for wiring together hardware devices, APIs, and online services using a visual programming interface.
Node-RED is a flow-based programming tool developed by IBM Emerging Technology and written in Node.js. It provides a browser-based editor for wiring together hardware devices, APIs, and online services using a visual programming interface. More information about Node-RED could be found [https://nodered.org/ here].


This article provides an extensive configuration example with details on how to use Node-RED with Teltonika Routers via MQTT and HTTP protocols.
This article provides an extensive configuration example with details on how to use Node-RED with Teltonika Routers via MQTT and HTTP protocols.
Line 16: Line 16:
*Linux Virtual Machine to host Node-RED server.
*Linux Virtual Machine to host Node-RED server.
-----
-----
There are a couple of different use cases with Node-RED and Teltonika devices and here are the connection topologies for these use cases.
There are a couple of different use cases with Node-RED and Teltonika devices:


Topology 1 – Modbus data to server using either Node-RED or Teltonika device as MQTT broker.
# [[Modbus_and_Bluetooth_data_sending_to_Node-RED#MQTT_Gateway | MQTT gateway using either Node-RED or Teltonika device as MQTT broker.]]
# [[Modbus_and_Bluetooth_data_sending_to_Node-RED#Modbus_Data_to_Server_via_MQTT_protocol | Modbus data to server using either Node-RED or Teltonika device as MQTT broker.]]
# [[Modbus_and_Bluetooth_data_sending_to_Node-RED#Bluetooth_Data_to_Server_via_MQTT_protocol | Bluetooth data to Node-RED server.]]
# [[Modbus_and_Bluetooth_data_sending_to_Node-RED#Modbus_Data_to_Server_via_HTTP_protocol | HTTP data to Node-RED server.]]


Topology 2 – Bluetooth data to server using Teltonika device as MQTT broker.
Topology 3 – MQTT gateway using either Node-RED or Teltonika device as MQTT broker.
Topology 4 – HTTP data to Node-RED server.
''Italic text''
==Node-RED installation and setup==
==Node-RED installation and setup==


Line 45: Line 42:
[[File:Server is running node red terminal.png|border|600px|class=tlt-border]]
[[File:Server is running node red terminal.png|border|600px|class=tlt-border]]
----
----
Once you have the local server running, use the local IP and port number in your internet browser. In this case, we are using 127.0.0.1:1880:
Once you have the local server running, use the local IP and port number in your internet browser. In this case, we are using '''127.0.0.1:1880''':
[[File:Use server address in web browser.png|border|500px|class=tlt-border]]
[[File:Use server address in web browser.png|border|500px|class=tlt-border]]


Line 55: Line 52:


==MQTT Gateway==
==MQTT Gateway==
MQTT Gateway allows to query the device from MQTT Clients, in this section we will configure it to work with the Node-RED.
===Using Teltonika device as an MQTT broker===
===Using Teltonika device as an MQTT broker===
----
Here is connection topology for this use case:
[[File:Nodered configurationexample topo5gw.png|border|700px|class=tlt-border]]
Router setup when using the router as a broker consists of two parts. First, we are going to set up a local broker. In order to do so, navigate to '''Services -> MQTT -> Broker''' and enable the broker.
Router setup when using the router as a broker consists of two parts. First, we are going to set up a local broker. In order to do so, navigate to '''Services -> MQTT -> Broker''' and enable the broker.


Line 61: Line 67:


Once done, navigate to '''Services -> Modbus -> MQTT Gateway'''. Follow these steps for the configuration:
Once done, navigate to '''Services -> Modbus -> MQTT Gateway'''. Follow these steps for the configuration:
*Enable the instance
# '''Enable''': on
*Host: since we are using a local broker on the router – input 127.0.0.1
# '''Host''': since we are using a local broker on the router – input 127.0.0.1
*Leave everything else as default, or adjust according to your needs
 
Leave everything else as default, or adjust according to your needs


[[File:MQTT gateway settings node red local router.png|border|500px|class=tlt-border]]
[[File:MQTT gateway settings node red local router.png|border|500px|class=tlt-border]]
Line 73: Line 80:
For this example, we are going to need '''MQTT-in''' and '''MQTT-out''' nodes. We are not going to need a broker node for now, since we are using our router as an MQTT broker. In order to send request and get response messages, we are also going to need '''inject''' and '''debug''' nodes. Drag required nodes onto the screen and click on them to configure accordingly:
For this example, we are going to need '''MQTT-in''' and '''MQTT-out''' nodes. We are not going to need a broker node for now, since we are using our router as an MQTT broker. In order to send request and get response messages, we are also going to need '''inject''' and '''debug''' nodes. Drag required nodes onto the screen and click on them to configure accordingly:


*'''MQTT-out node''' - click on this node and then click on the pencil icon to configure Node-RED for Teltonika broker usage.
*'''MQTT-out node''' - click on this node and then click on the '''pencil''' icon to configure Node-RED for Teltonika broker usage.


[[File:Click on the pencil nodered broker local.png|border|500px|class=tlt-border]]
[[File:Click on the pencil nodered broker local.png|border|500px|class=tlt-border]]
Line 79: Line 86:
In the next screen configure settings accordingly:
In the next screen configure settings accordingly:


*Name: RUT_broker for this example
# '''Name''': RUT_broker for this example
*Server: 192.168.10.1 (Router's LAN IP address)
# '''Server''': 192.168.10.1 (Router's LAN IP address)
*Port: Default port 1883
# '''Port''': Default port 1883
*Leave everything else as default or adjust to your needs
# Press '''Update'''


[[File:Mqtt broker on our router settings.png|border|500px|class=tlt-border]]
[[File:Mqtt broker on our router settings.png|border|500px|class=tlt-border]]
----
----
Now we are going to go back to MQTT-out node configuration and adjust settings as shown below:
Now we are going to go back to MQTT-out node configuration and adjust settings as shown below:
*Server: RUT_broker
 
*Topic: request
# '''Server''': RUT_broker
# '''Topic''': request
# Press '''Done'''


[[File:Mqtt out request node red.png|border|500px|class=tlt-border]]
[[File:Mqtt out request node red.png|border|500px|class=tlt-border]]
Line 94: Line 103:
----
----


*'''MQTT-in node''' - configure settings as shown below:
'''MQTT-in node''' - configure settings as shown below:


*Server: RUT_broker
# '''Server''': RUT_broker
*Action: Subscribe to single topic
# '''Action''': Subscribe to single topic
*Topic: response
# '''Topic''': response
*QoS: 0
# '''QoS''': 0
*Output: auto-detect
# '''Output''': auto-detect
# Press '''Done'''


[[File:Mqtt in response node red.png|border|500px|class=tlt-border]]
[[File:Mqtt in response node red.png|border|500px|class=tlt-border]]
Line 114: Line 124:
There is no need to configure '''debug''' node. Here is how the finished flowchart should look like:
There is no need to configure '''debug''' node. Here is how the finished flowchart should look like:


[[File:Flowchart nodered local broker on router.png|border|500px|class=tlt-border]]
[[File:Flowchart nodered local broker on router.png|border|400px|class=tlt-border]]


----
----
Line 130: Line 140:
===Using Node-RED as an MQTT broker===
===Using Node-RED as an MQTT broker===
----
----
Here we are using Node-RED as MQTT Broker, so we are going to do necessary changes in order for this functionality to work.
Here is the connection topology for this use case:
[[File:Nodered configurationexample topo1.png|border|700px|class=tlt-border]]
====Adjusting Node-RED configuration====
====Adjusting Node-RED configuration====


If you would like to use Node-RED as a broker, there are a couple of changes needed to be made. Similarly as shown before, we are going to need to set up local broker like this:
If you would like to use Node-RED as a broker, there are a couple of changes needed to be made. Similarly as shown before, click on '''MQTT Subscriber''' node and click edit in the Server section. Input name '''(1)''' and address '''127.0.0.1''' '''(2)''' in order to use Node-RED broker and press '''Done'''.


[[File:Local broker settings nodered.png|border|500px|class=tlt-border]]
[[File:Local broker settings nodered.png|border|500px|class=tlt-border]]
Line 141: Line 158:


====Adjusting Teltonika device configuration====
====Adjusting Teltonika device configuration====
Navigate to '''Services -> Modbus -> MQTT Gateway'''. Change the host IP to your Linux Virtual Machine IP address (192.168.10.139 in this example):
[[File:Using local node red broker just change the IP address of broker.png|border|500px|class=tlt-border]]
To test the configuration, '''deploy''' the nodes again and send the message by clicking on the '''inject''' node.
===MQTT gateway using MQTT explorer and Node-RED broker===
----
In this example, we are going to use the same Node-RED broker configured in previous parts of this article, only this time we are going to use [http://mqtt-explorer.com/ MQTT Explorer] app to Publish and Subscribe to Modbus data.
Here's connection topology for this use case:
[[File:Nodered configurationexample topo6.png|border|800px|class=tlt-border]]
====Device setup====
----
Navigate to '''Services -> Modbus -> MQTT Gateway'''. Follow these steps for the configuration:
# '''Enable''': on
# '''Host''': input '''192.168.10.139''', or if you would like to use local broker on the device - input '''127.0.0.1'''
Leave everything else as default, or adjust according to your needs
[[File:MQTT gateway settings node red local router.png|border|500px|class=tlt-border]]
====MQTT explorer setup and testing====
----
Open MQTT Explorer application and in the default screen input the '''Host IP (1)'''  of MQTT Broker, then press '''Connect (2)'''.
[[File:Mqtt explorer server connection to broker example.png|border|600px|class=tlt-border]]
Once done, locate Publish section on the right side. You can use the same settings as in previous sections of MQTT Gateway:
# '''Topic:''' request
# '''Data:''' 0 65432 0 192.168.10.1 502 5 1 3 6 2
[[File:Publish from mqtt explorer node red example.png|border|500px|class=tlt-border]]
If everything is set up correctly, then you should be able to see response from the router:
[[File:Mqtt explorer response from router.png|border|400px|class=tlt-border]]
==Modbus Data to Server via MQTT protocol==
In this section, we are going to upload Modbus data to server on Node-RED. First of all, we are going to need Modbus data source, in this example we are using the same device as Modbus TCP Slave and Master.
Here's connection topology for this use case:
[[File:Nodered configurationexample topo2.png|850px|class=tlt-border]]
===Device configuration===
----
To start with, navigate to '''Services -> Modbus -> Modbus TCP slave'''. Press '''enable''' to enable the instance and you can leave everything else as '''default''':
[[File:Nodered modbusenable.png|border|600px|class=tlt-border]]
Next, navigate to '''Services -> Modbus -> Modbus TCP master'''. Adjust settings here accordingly:
# '''Enabled''': on
# '''Name''': Local_slave (input any preferred name)
# '''Slave ID''': 1
# '''IP address''': 127.0.0.1 (since we are using local TCP slave - input the IP address of your slave if you are using external device as Modbus Slave)
# '''Port''': 502
[[File:Nodered tcpmaster config.png|border|600px|class=tlt-border]]
Add new request and adjust settings according to your needs. For this example, we are going to pull device name from the registers, so our configuration looks like this:
# '''Name''': test (input any preferred name)
# '''Data type''': ASCII (to get a string of text)
# '''Function''': Read holding registers (3)
# '''First register number''': 72
# '''Register count/values''': 3
# '''Brackets''': use brackets
Press enable to enable the Modbus request.
[[File:Tcp master nodered.png|border|1050px|class=tlt-border]]
----
To finish up the device configuration, navigate to '''Services -> Data to server.''' Add new data sender and configure settings accordingly:
# '''Enable''': on
# '''Name''': Data_to_node (input any preferred name)
# '''Data source''': MODBUS data
# '''Protocol''': MQTT
# '''JSON format''': {"Router name": %a} - adjust this according to your needs
# '''URL/Host/Connection string''': 192.168.10.139 (virtual machine address)
# '''Port''': 1883
# '''Topic''': rutx (input any preferred topic, make sure to subscribe on the same topic)
[[File:Data sender settings to node red with node red broker.png|border|800px|class=tlt-border]]
===Node-RED setup===
----
Node-RED setup to get Modbus data is simple, we are going to need one '''MQTT Subscriber''' node, one '''MQTT broker''' node so we could use broker on Node-RED and we will use '''debug''' node to read MQTT messages. Here is how the flowchart should look like:
[[File:Local flowchart data sender.png|border|400px|class=tlt-border]]
Adjust MQTT Subscriber node settings accordingly:
# '''Server''': Local (from previous example)
# '''Action''': Subscribe to single topic
# '''Topic''': rutx
Leave everything else as default.
[[File:Server local subscriber node red.png|border|500px|class=tlt-border]]
Deploy the nodes and look for incoming data in the debug window - based on '''Period''' time in Data to server settings. Here is incoming message with router name:
[[File:Incoming data from router nodered.png|border|400px|class=tlt-border]]
If you would like to use MQTT broker on the Teltonika device, change '''Server: Local''' to Server: '''RUT_Broker''' (which uses the IP 192.168.10.1).
==Bluetooth Data to Server via MQTT protocol==
In this section, we are going to upload Bluetooth data to server on Node-RED. The configuration is going to be similar to Modbus data to server. More information about Bluetooth functionality ant usage with beacons could be found in [[Teltonika EYE device pairing and data sender configuration example]].
Here's connection topology for this use case:
[[File:Nodered configurationexample topo3.png|border|800px|class=tlt-border]]
===Device configuration===
----
First of all we are going to need a Bluetooth device which is paired to Teltonika device. For this example, we are using Teltonika [https://teltonika-gps.com/eye/?gclid=Cj0KCQiAq5meBhCyARIsAJrtdr6f7Mvt5UtlJQag03K5nXDeXiHhdLDl-MavVEljCg1PlDhxPp3jJnEaAnxfEALw_wcB EYE Beacon] and we have it paired to the device. You can pair Bluetooth device by navigating to '''Services -> Bluetooth''' and clicking '''Scan'''. Then select your device and click '''Pair'''. Here's how a paired device looks like:
[[File:Paired beacon2 nodered.png|border|1000px|class=tlt-border]]
After that, navigate to '''Services -> Data to server.''' Add new data sender and configure settings accordingly:
# '''Enable''': on
# '''Name''': BT_data (input any preferred name)
# '''Data source''': Bluetooth data
# '''Protocol''': MQTT
# '''JSON format''': {"Data": "%b", "Hour": "%d"} - adjust this according to your needs
# '''URL/Host/Connection string''': 192.168.10.139 (virtual machine address)
# '''Port''': 1883
# '''Topic''': beacon (input any preferred topic, make sure to subscribe on the same topic)
[[File:Bluetooth data sender settings rutx11.png|border|800px|class=tlt-border]]
===Node-RED setup===
----
The setup is the same as with Modbus data to server, just change MQTT Subscriber settings to subscribe on the '''beacon''' topic. if everything is setup correctly, you will be able to see incoming messages on the right side of the screen:
[[File:Data from beacon nodered.png|border|400px|class=tlt-border]]
==Modbus Data to Server via HTTP protocol==
In this section, we will adjust the configuration in order to get the data via HTTP protocol.
Here's connection topology for this use case:
[[File:Nodered configurationexample topo4.png|border|800px|class=tlt-border]]
===Device configuration===
----
Look into Modbus data to server via MQTT section for Modbus Slave and Master setup. Navigate to navigate to '''Services -> Data to server.''' Add new data sender and configure settings accordingly:
# '''Enable''': on
# '''Name''': tcp (input any preferred name)
# '''Data source''': MODBUS data
# '''Protocol''': HTTP(S)
# '''JSON format''': {"Data": %a} - adjust this according to your needs
# '''URL/Host/Connection string''': 192.168.10.139:8080 (virtual machine address and port number)
[[File:Modbus data http to node red.png|border|800px|class=tlt-border]]
===Node-RED setup===
----
For this configuration we are going to need two nodes: '''TCP''' and '''debug'''. Drag in both nodes and click on TCP node. Adjust settings accordingly:
# '''Type''': Listen on port '''8080'''
# '''Output''': stream of '''String''' payload
[[File:Tcp listening on port 8080 node settings.png|border|500px|class=tlt-border]]
Flowchart for this example should look like this:
[[File:Nodered configurationexample flowchartforhttp v1.png|border|400px|class=tlt-border]]
===Testing the configuration===
----
If configured correctly, you should be able to see incoming Modbus data to the Node-RED debug window:
[[File:Nodered configurationexample httpData incoming v1.png|border|400px|class=tlt-border]]
==Summary==
In this article, several use cases are discussed, such as MQTT gateway using Node-RED or Teltonika device as MQTT broker, Modbus data to server, Bluetooth data to server, HTTP data to Node-RED server, and MQTT gateway using MQTT Explorer. The article provides steps on how to install Node-RED on a Linux virtual machine, install MQTT-specific nodes, and set up a local server. The article also explains how to use the Teltonika device as an MQTT broker and set up Node-RED to work with it.
==References==
[https://nodered.org/ Node-RED]
[[Modbus TCP Master MQTT Gateway]]
[[Teltonika EYE device pairing and data sender configuration example]]
[http://mqtt-explorer.com/ MQTT Explorer]