- Use case
- Prerequisites
- Step 1: Creating the rule chain
- Step 2: Validation the rule chain logic
- TL;DR
- Next steps
Use case
Let’s assume you need to implement the “counter” logic using ThingsBoard Rule Engine. Basically, message processing is executed asynchronously inside the rule nodes. Due to this fact, in most cases, the logic “get present counter value -> add new counter value -> save counter value” leads to the incorrect final result (unlike your expectations) due to the race condition issue. It is a well-known problem for all who dealt with multi-threading programming. You can refer to this article which nicely describes the problem and the existed solutions. Starting the ThingsBoard v2.5 this processing issue could be solved using special configurable queues.
In this tutorial, we will configure ThingsBoard Rule Engine to use queue with sequential by originator message submit strategy. Although this scenario is fictional, you will learn how to work with the queue to allow processing messages in sequential order and use this knowledge in real-life applications.
Prerequisites
We assume you have completed the following guides and reviewed the articles listed below:
- Getting Started guide.
- Rule Engine Overview.
In addition, you need to have at least one device provisioned in your environment.
Step 1: Creating the rule chain

We will add two generator nodes that will generate seven messages each. First generator will produce a message with the counter value of 101. The second one - with the value of 10. So the result should be 777.
 

Both messages will be put into the SequentialByOriginator queue. It uses the message submit strategy SEQUENTIAL_BY_ORIGINATOR which means that the subsequent message will start being processed when the preceding message is acknowledged (is processed and deleted from the queue) based on the originator.
We will get the present “counter” value using originator attributes node. Tell failure if any of the attributes are missing is currently disabled because the device does not have the required attribute and will cause an error.
This attribute will be set to the device after the first message reaches the save attributes node.

The calculations will be done using script node.

The last step will be to save the new counter value using save attributes node.

Step 2: Validation the rule chain logic
Let’s check that our logic is correct by saving the Rule Chain. The generators will automatically produce 14 messages:

The final counter value that is persisted for a device is:

That means that our logic works correctly.
TL;DR
Download and import attached json file with a rule chain from this tutorial. Don’t forget to populate the Generator nodes with your specific device.
Next steps
- 
    Getting started guides - These guides provide quick overview of main ThingsBoard features. Designed to be completed in 15-30 minutes. 
- 
    Connect your device - Learn how to connect devices based on your connectivity technology or solution. 
- 
    Data visualization - These guides contain instructions on how to configure complex ThingsBoard dashboards. 
- 
    IoT Data analytics - Learn how to use rule engine to perform basic analytics tasks. 
- 
    Advanced features - Learn about advanced ThingsBoard features. 
- 
    Contribution and Development - Learn about contribution and development in ThingsBoard. 
