Monitoring and Optimizing Node-RED Flows with Open Telemetry.
Integrating Open Telemetry with Node-RED for Efficient Distributed Tracing
Have you ever found yourself frustrated by unexpected delays in your Node-RED flows, wondering where the bottlenecks are hiding? Even small latency issues can have a big impact on your system's performance. That's where Open Telemetry comes in. With its powerful distributed tracing capabilities, you can finally take control and get a clear view of how your flows are performing in real time.
Integrating Open Telemetry with Node-RED allows you to monitor latency across your flows. By implementing distributed tracing, you’ll gain the ability to see exactly where delays occur, helping you optimize performance and ensure your IoT applications run efficiently.
# What is Distributed Tracing and How Does Open Telemetry Help?
Distributed tracing is a method used to track and observe the flow of requests through different services within a distributed system. It provides insights into how requests are handled, where delays occur, and how different components interact. By visualizing the path of a request across your system, distributed tracing helps you identify performance bottlenecks and optimize the overall efficiency of your applications.
# What is OpenTelemetry?
Open Telemetry is an open-source framework designed to help you monitor and understand your software systems. It collects and organizes data on how your applications perform and behave, allowing you to track requests as they move through various services. Open Telemetry provides a standardized way to gather and analyze telemetry data, including traces, metrics, and logs, to give you a comprehensive view of your system’s performance.
In Node-RED The Open Telemetry module helps track messages by creating "spans" that record details about each message's journey. Every time a message moves from one node to another, a span is created to capture where it came from, where it’s going, and how long it took. These spans are linked together, showing the entire path of the message through the system. This makes it easier to spot slowdowns, fix problems, and improve how data moves through Node-RED. The module also makes sure this tracking information follows the message as it moves across different nodes and external services.
# Tracing in Node-RED Flows using Opentelemetry
In a manufacturing plant, Node-RED manages different machines and sensors. Suppose there's a problem with the production line, such as a delay in processing or a GPIO node experiencing issues reading data. With Open Telemetry integrated, you can trace the data flow through the system to see exactly where the issue is happening. This helps you quickly identify whether the problem is with a specific node that is reading the machine data or a delay in data processing, allowing you to fix the issue faster and keep the production line running smoothly.
For demonstration purposes, we will use a flow that simulates sensor reading and data processing. We will monitor this flow using Open Telemetry to track data across the system, identify bottlenecks, and optimize performance.
Deploy the flow above, and you might see a delay in the data shown on the debug panel. For this example, we added a Delay node before the Change node that converts temperature data from Kelvin to Celsius. While this delay is visible here, finding such delays in larger flows with many nodes can be difficult and time-consuming. Open Telemetry makes this easier by giving you detailed traces that show where delays or issues are happening
# Prerequisite
Before you start, ensure you have the following:
- node-red-contrib-opentelemetry : Install this Node-RED module via the Node-RED Palette Manager.
- Open Telemetry exporter: Set up an Open Telemetry exporter to send trace data to a backend. For details on available exporters, visit Open Telemetry Exporters. For this guide, I have set up the Jaeger.
# Setting Open Telemetry in Node-RED
Screenshot showing the configuration of opentelmetry node
- Drag an
OTEL
node onto the canvas. - Double-click on the node and set the URL to your exporter endpoint (e.g.,
http://localhost:4318/v1/traces
for a locally running Jaeger exporter). Provide a name for the service according to your preference, and set the Prefix, which will be added to the root Node-RED span name before the initial node name (you can keep it as "Message" if preferred). - In the Ignore field, add the names of nodes you want to exclude from Open Telemetry tracing.
- In the Propagate field, add the names of nodes if you want them to forward trace headers to external systems or other nodes in the flow. This ensures that these nodes participate in the distributed trace, allowing the trace context to be maintained across different components.
- Set the Timeout to define how long (in seconds) the OTEL node should wait before ending and discarding a message that has not been modified.
- Now deploy the flow by clicking on the top-right deploy button.
Once the flow is deployed, Open Telemetry will start collecting and sending trace data to your specified exporter.
# Monitoring Performance Using the Exporter Web UI
Now, let's monitor the performance and latency between each node to identify delays. For this section, I am assuming you have Jaeger running as your exporter.
- Open the Jaeger web UI in your browser. By default, it will be available at
http://localhost:16686/
. - Navigate to the "Search" by clicking on the "Search" option at the top.
- Select the service name that you configured in the OTEL node from the service field. Once selected, you will see all the traces for each interaction in the flow. You can filter the traces by specific nodes using the operation field.
- To monitor and find issues, select the desired trace and click on the "Find Trace" button. Click on the first trace to examine it.
Once the trace opens, you will see the duration taken by each node to process and pass data. Notice the time taken by the delay node, which is 2 seconds, indicating the problem. By clicking on the green line corresponding to this delay node, you can view more detailed information about the trace.
Image showing the tototal duration taken by the flow
Since the issue was identified with the delay node, let's remove that delay node.
After updating the flow, redeploy the flow and check the traces again. You should see that the total time has been reduced significantly, with the overall flow now taking around 8 milliseconds instead of the previous 2 seconds. This demonstrates how Open Telemetry helps in identifying and resolving performance issues in your Node-RED flows.
Image showing the total duration taken by the flow after fixing the issue
Throughout this guide, we’ve interacted with an exporter which is running locally. However, by deploying and setting up your exporter on a server, you can remotely monitor the performance of your Node-RED flows. This setup enables you to oversee your system's performance from anywhere, making it easier to detect and address issues promptly.
# Conclusion
Using Open Telemetry with Node-RED helps you spot and fix delays in your flows quickly. By tracking data through your system, you can see where things slow down and make improvements. This makes your IoT applications run smoother and more efficiently. With the steps in this guide, you're now ready to use distributed tracing to keep your Node-RED flows performing at their best.
Written By:
Published on:
Recommended Articles:
- How to create and use Subflow in Node-RED
- How to Use If-Else Logic in Node-RED: A Step-by-Step Guide
- Using AMQP with Node-RED
- FlowFuse 2.8: Static File Service, LDAP Updates & More
- New Layout, Widget and Gauges Now Available in FlowFuse Dashboard