- Prerequisites
- Step 1. Connecting Device and Sending Telemetry Data
- Step 2. Creating Dashboard and Configuring Widgets
- Step 3. Pushing Data From Edge to Cloud
- Step 4. Provisioning Entities From Edge to Server
- Step 5. Provisioning Entities From Server to Edge
- Your Feedback
- Next steps
This tutorial will guide you through the fundamentals of the ThingsBoard Edge platform and introduce you to the most widely used features. From this tutorial, you will learn how to:
- Install and run ThingsBoard Edge on your machine.
- Connect local devices, such as temperature sensors.
- Transmit data from the device to the Edge and then from the Edge to the ThingsBoard Cloud.
- Create and configure real-time dashboards.
To keep it simple, we will skip over lengthy descriptions. However, if you need more detailed information, check out the “What is ThingsBoard Edge” article and explore our other documentation.
Prerequisites
To start running ThingsBoard Professional Edition Edge, you will need an active ThingsBoard Professional Edition account that supports Edge functionality.
Sign up for a ThingsBoard Cloud account, which is the easiest way to get started. Throughout the rest of this tutorial, this URL will be referred to as SERVER_URL Log in using your ThingsBoard Cloud tenant credentials. |
You can install the ThingsBoard Professional Edition local server. For this, please refer to the ThingsBoard installation guide. The local server can be accessed via http://localhost:8080. Throughout this tutorial, we will refer to this URL as SERVER_URL. Log in with:
|
Edge Hardware Requirements
The hardware requirements for ThingsBoard Edge are determined by the number of connected devices and the intensity of interactions with the platform interface. To ensure optimal performance, we recommend the following:
- At least 1GB of RAM (Light workload): It is suitable for minimal interactions with the platform interface, such as dashboards and device management, and fewer than 100 connected devices.
- At least 4GB of RAM (Heavy workload): This configuration is suitable for intense platform interactions and 100+ devices connected to a single machine.
Deploying a New Edge Instance
To create a new Edge:
-
Sign in to your ThingsBoard PE instance and navigate to the Edge Management > Instances section. Click the ”+” icon in the top right corner and select the “Add new edge” option.
-
Enter a name for the Edge you are creating. For example, “My New Edge”. If needed, update the cloud endpoint.
- If the Edge runs in a Docker container, do not use “localhost” as the endpoint. Instead, use the IP address of the machine where ThingsBoard PE is hosted and accessible by the Edge container. For example, http://10.7.2.143:8080.
- If you are using the ThingsBoard Cloud, there’s no need to change this setting — keep it as is.
- Click the “Add” button to confirm the addition of the Edge instance.
-
Your new Edge is created and will appear at the top of the list, as entries are sorted by creation time by default.
data:image/s3,"s3://crabby-images/cfd2b/cfd2b1b79df6d40c2414c1a8c04da7e87735b0cb" alt="Sign in to your ThingsBoard PE instance and navigate to the Edge Management > Instances section. Click the "+" icon in the top right corner and select the "Add new edge" option."
Sign in to your ThingsBoard PE instance and navigate to the Edge Management > Instances section. Click the ”+” icon in the top right corner and select the “Add new edge” option.
data:image/s3,"s3://crabby-images/e94fc/e94fc4b8650001a564f052035e316d90353971ff" alt="Enter a name for the Edge you are creating. For example, "My New Edge". If needed, update the cloud endpoint.
If the Edge runs in a [Docker container"{:target="_blank"}, do not use “localhost” as the endpoint. Instead, use the IP address of the machine where ThingsBoard PE is hosted and accessible by the Edge container. For example, http://10.7.2.143:8080.
If you are using the ThingsBoard Cloud, there’s no need to change this setting — keep it as is.
Click the "Add" button to confirm the addition of the Edge instance.](/images/pe/edge/installation-add-edge-item-2-preview.png)
Enter a name for the Edge you are creating. For example, “My New Edge”. If needed, update the cloud endpoint.
- If the Edge runs in a Docker container, do not use “localhost” as the endpoint. Instead, use the IP address of the machine where ThingsBoard PE is hosted and accessible by the Edge container. For example, http://10.7.2.143:8080.
- If you are using the ThingsBoard Cloud, there’s no need to change this setting — keep it as is.
- Click the “Add” button to confirm the addition of the Edge instance.
data:image/s3,"s3://crabby-images/ef6c4/ef6c40deb37b478d502a92d3e4dbbe3df2ca25e9" alt="Your new Edge is created and will appear at the top of the list, as entries are sorted by creation time by default."
Your new Edge is created and will appear at the top of the list, as entries are sorted by creation time by default.
Edge Installation and Configuration
Guided Installation with ThingsBoard Server Pre-configured Instructions
Once the Edge instance has been created, the installation instructions will be available for use. Each Edge has preset configurations that contain important credentials, such as Edge Secret, Edge Key, etc. To access these configurations:
-
Click on the Edge entity to open its details.
-
Click the “Install & Connection Instructions” button.
-
Follow the instructions to install Edge and connect it to the server.
data:image/s3,"s3://crabby-images/219d9/219d956a79fabaccc4539ee57ea89001020339e5" alt="Click on the Edge entity to open its details."
Click on the Edge entity to open its details.
data:image/s3,"s3://crabby-images/af723/af723fdf0a25c8d724e0c439a0dfed05a88b2656" alt="Click the "Install & Connection Instructions" button."
Click the “Install & Connection Instructions” button.
data:image/s3,"s3://crabby-images/15975/15975bf04b19b32f90f607249597378352fd7f41" alt="Follow the instructions to install Edge and connect it to the server."
Follow the instructions to install Edge and connect it to the server.
Accessing User Interfaces: URLs and Credentials
Once Edge is installed, you’ll be able to access the interface via http://localhost:8080. Throughout the rest of this tutorial, this URL will be referred to as EDGE_URL Please log in using your ThingsBoard Cloud tenant credentials. |
Once Edge is installed, you’ll be able to access the interface via http://localhost:18080. This URL will be referred to as EDGE_URL throughout the rest of this tutorial. To log in, use the same credentials as SERVER_URL:
|
Step 1. Connecting Device and Sending Telemetry Data
In ThingsBoard, the device is the key entity that generates telemetry data, which is stored and processed for dashboards and analytics. ThingsBoard also provides a virtual device shell for sending telemetry on behalf of the physical device for testing purposes.
To add a new device on the Edge, log in to your ThingsBoard Edge instance at EDGE_URL and follow these steps:
- Go to the Entities > Devices section.
- Click the "+" icon and select the "Add new device" option. Enter a name for the device, for example, "My New Device". No other changes are required. Click the "Add" button to create the device.
- After the device is created, instructions on how to check its connectivity will be provided. Select the messaging protocol and your operating system. Install the required client tools, then copy the provided command.
- Run the previously copied command. Once the "temperature" readings are published, the device state will change from "Inactive" to "Active", and you will see the published "temperature" readings. Finally, close the connectivity window.
- To verify the received telemetry, click on the device entity and open the "Latest Telemetry" tab.
data:image/s3,"s3://crabby-images/16b90/16b9053f768d2a016984f38819c9734e0677550a" alt="Go to the <b>Entities > Devices</b> section."
data:image/s3,"s3://crabby-images/ca8a7/ca8a7363f1a862a3a72276160a7496ea635b3d0d" alt="Click the <b>"+"</b> icon and select the <b>"Add new device"</b> option. Enter a name for the device, for example, "My New Device". No other changes are required. Click the <b>"Add"</b> button to create the device."
data:image/s3,"s3://crabby-images/9319d/9319d434d24b9ca579b44131e48580019cb5a42f" alt="After the device is created, instructions on how to check its <b>connectivity</b> will be provided. Select the <b>messaging protocol</b> and your <b>operating system</b>. Install the required client tools, then copy the provided command."
data:image/s3,"s3://crabby-images/0b46a/0b46a378687c1754dc6e4698d046f40dbc9cc666" alt="Run the previously copied command. Once the "temperature" readings are published, the device state will change from <span style="color:red">"Inactive"</span> to <span style="color:green">"Active"</span>, and you will see the published "temperature" readings. Finally, close the connectivity window."
data:image/s3,"s3://crabby-images/8b092/8b092a9300be8702e3d5b7665f1093aaf8e5d230" alt="To verify the received telemetry, click on the device entity and open the <b>"Latest Telemetry"</b> tab."
In addition, the following may be used:
- Bulk provisioning: Use to deploy multiple devices from a CSV file via user interface.
- REST API: Use to add devices and other entities programmatically.
Step 2. Creating Dashboard and Configuring Widgets
A Dashboard is another key entity within ThingsBoard. It allows you to visualize IoT data and control devices through the user interface.
To create a dashboard, login to your ThingsBoard Edge instance and navigate to the Dashboard section. Then, follow these steps:
- Click the "+" icon and select the "Create new dashboard" option from the drop-down menu.
- Enter the dashboard name, for example, "New Dashboard", and click the "Add" button to create the dashboard.
data:image/s3,"s3://crabby-images/7ad4d/7ad4d3ffdd678dffdcaf51dd825b8711e99b822a" alt="Click the <b>"+"</b> icon and select the <b>"Create new dashboard"</b> option from the drop-down menu."
data:image/s3,"s3://crabby-images/d01cc/d01cce9d8feeb7fa41c7ead1a02b0ee927d34a9d" alt="Enter the dashboard name, for example, "New Dashboard", and click the <b>"Add"</b> button to create the dashboard."
Once the dashboard is created, the system will automatically redirect you to the Edit mode page. To add a widget, select one from the widget library, where widgets are grouped into bundles. Each widget is linked to a data source, which defines the data it will display.
For example, let’s add and configure the Entities table and Time series chart widgets:
- Click the "Add widget" button.
- Locate the "Tables" bundle and click on it.
- Select the "Entities table" widget.
- In the "Add Widget" pop-up window, select the previously created device, "My New Device", in the "Device" field.
- The “name” key has already been added to the “Columns” section. It will display the column with the device name.
- To add another column with different key value, click the "Add column" button.
- To select an additional data key to display, click on the newly appeared field. In the drop-down menu, you will see the list of the available data keys. Select the "temperature" data key. Click the "Add" button.
- The "Entities table" widget has been added, and "My New Device" is now displayed in the list. To add another widget, click the "Add widget" button.
- Locate the "Charts" widgets bundle and click on it.
- Select the "Time series chart" widget.
- Select the previously created device, "My New Device", as the data source, and click the "Add" button. The "Time series chart" widget has been successfully added to the dashboard.
- After configuring all the desired widgets, you can adjust their size and placement on the dashboard as needed. Drag and drop the widget to reposition it on the dashboard.
- To resize the widget, drag its bottom-right corner.
- To apply all changes to the dashboard, click the "Save" button in the upper-right corner of the screen.
- Congratulations! You have successfully configured the dashboard. Now, all new telemetry readings will instantly appear on the dashboard widgets.
data:image/s3,"s3://crabby-images/b4b61/b4b61c0209935e26f8c44c2e9951c7c84f1a32a1" alt="Click the <b>"Add widget"</b> button."
data:image/s3,"s3://crabby-images/483d0/483d03f45d39d0633d2234a307ab56fb1b65c070" alt="Locate the <b>"Tables"</b> bundle and click on it."
data:image/s3,"s3://crabby-images/60f81/60f81ab5c96dbc7794387b4caa543a3e232f6f66" alt="Select the <b>"Entities table"</b> widget."
data:image/s3,"s3://crabby-images/68a18/68a18ae05d9cad6d8625ec54be6f7289ace53b2c" alt="In the <b>"Add Widget"</b> pop-up window, select the previously created device, "My New Device", in the <b>"Device"</b> field.<ul><li>The <b>“name”</b> key has already been added to the <b>“Columns”</b> section. It will display the column with the device name.</li><li>To add another column with different key value, click the <b>"Add column"</b> button.</li></ul>"
- The “name” key has already been added to the “Columns” section. It will display the column with the device name.
- To add another column with different key value, click the "Add column" button.
data:image/s3,"s3://crabby-images/5160c/5160cdb294dab3706dbb5a7b95f54af6956d619e" alt="To select an additional data key to display, click on the newly appeared field. In the drop-down menu, you will see the list of the available data keys. Select the <b>"temperature"</b> data key. Click the <b>"Add"</b> button."
data:image/s3,"s3://crabby-images/03fd1/03fd1d93ad8d39616b8773af0a8dc9892a37ae78" alt="The <b>"Entities table"</b> widget has been added, and <b>"My New Device"</b> is now displayed in the list. To add another widget, click the <b>"Add widget"</b> button."
data:image/s3,"s3://crabby-images/bd5e0/bd5e063b3922094e83ecef77a01e3630a82cdcdc" alt="Locate the <b>"Charts"</b> widgets bundle and click on it."
data:image/s3,"s3://crabby-images/4f13e/4f13eb4cb9d874729b0e4c2c8833622600c7b7bd" alt="Select the <b>"Time series chart"</b> widget."
data:image/s3,"s3://crabby-images/8086c/8086c43797f8e408940274b13b7696ae390ca8a7" alt="Select the previously created device, "My New Device", as the <b>data source</b>, and click the <b>"Add"</b> button. The <b>"Time series chart"</b> widget has been successfully added to the dashboard."
data:image/s3,"s3://crabby-images/ed4b0/ed4b0db515963c8d4b8f1f78a0f81f9c3db48520" alt="After configuring all the desired widgets, you can adjust their size and placement on the dashboard as needed. Drag and drop the widget to reposition it on the dashboard."
data:image/s3,"s3://crabby-images/92136/9213603d0b1d1bffe83c2e5ee2feed2cbe726120" alt="To resize the widget, drag its bottom-right corner."
data:image/s3,"s3://crabby-images/b242d/b242d1988fbc43c5b604d451cefe8f2d4618c951" alt="To apply all changes to the dashboard, click the <b>"Save"</b> button in the upper-right corner of the screen."
data:image/s3,"s3://crabby-images/bccff/bccffe80cc5417f122cd5a39132cbd5f805eb85c" alt="Congratulations! You have successfully configured the dashboard. Now, all new telemetry readings will instantly appear on the dashboard widgets."
Step 3. Pushing Data From Edge to Cloud
To process data on site, and communicate with local and cloud-side services, the Edge Rule Chain Template is used.
In essence, the Edge Root Rule Chain refers to the Rule Chain within the ThingsBoard Edge that processes incoming data and can trigger specific actions based on certain conditions.
To understand how the telemetry data is transmitted from the Edge to the Cloud, let’s review the default Edge Root Rule Chain:
- Within your Edge instance, go to the Rule Chains section and open the "Edge Root Rule Chain".
- The Push to Cloud rule node is used to transmit messages from edge to cloud after they have been stored in the local database.
data:image/s3,"s3://crabby-images/d927a/d927ad5a359cf3d3852eb2ac335a54d34fc40684" alt="Within your <b>Edge</b> instance, go to the <b>Rule Chains</b> section and open the <b>"Edge Root Rule Chain"</b>."
data:image/s3,"s3://crabby-images/0fa40/0fa409693023f6cab496b6152e9b01bcf37400da" alt="The <a href="/docs/pe/user-guide/rule-engine-2-0/action-nodes/#push-to-cloud" target="_blank">Push to Cloud</a> rule node is used to transmit messages from edge to cloud after they have been stored in the local database."
Step 4. Provisioning Entities From Edge to Server
Any real-world assets, devices, sensors or other logical components are represented within ThingsBoard as corresponding entities. Most of the entities can be created on the Edge instance. Once an entity is created on the Edge instance, it will be automatically published to the ThingsBoard Server, requiring no additional actions.
To view the published entity (e.g., device), log in to the ThingsBoard Professional Edition at SERVER_URL:
- Navigate to the Devices section to confirm that the newly created device, "My New Device", has been published to the ThingsBoard Server (Cloud).
- Click on the "My New Device" to open the "Device details" page and select the "Relations" tab. Switch the direction from "From" to "To" to view the relation to the Edge that provisioned this device.
data:image/s3,"s3://crabby-images/18f5a/18f5a1f635410dd7a1541942daaedc95b80838a8" alt="Navigate to the <b>Devices</b> section to confirm that the newly created device, "My New Device", has been published to the <b>ThingsBoard Server (Cloud)</b>."
data:image/s3,"s3://crabby-images/d4ca1/d4ca1c6f7c9eeaa18a54d8c83111fbc12dd7ac06" alt="Click on the "My New Device" to open the <b>"Device details"</b> page and select the <b>"Relations"</b> tab. Switch the direction from <b>"From"</b> to <b>"To"</b> to view the relation to the Edge that provisioned this device."
Step 5. Provisioning Entities From Server to Edge
The entities can also be created on the Server and then assigned to the Edge instance. This approach simplifies the management of entities across multiple Edge instances.
To assign entities to the Edge, log in to your ThingsBoard Professional Edition Server at SERVER_URL and create an entity, for example, a dashboard.
- Create a new dashboard on the ThingsBoard Server. Click the "Dashboard details" icon to view details;
- Click the "Manage owner and groups" button;
- Now, create a new dashboard group and add the previously created dashboard to it. Enter a name for the new dashboard group (for example, "Edge Dashboard Group") in the "Groups" field, and click the "Create a new one!" link.
- In the "Add entity group" pop-up window, click the "Add" button.
- The "Edge Dashboard Group" appears in the "Groups" field. Click the "Update" button.
- The newly created group is now available in the "Groups" column.
- Go to the Edge management > Instances section. Click the "Manage edge dashboard groups" icon of the instance in question.
- On the Edge Dashboard Groups page, you will see all the dashboard groups that are already assigned to this Edge. To assign another dashboard group, click the "+" icon and select "Edge Dashboard Group" from the drop-down-menu. Click the "Assign" button.
data:image/s3,"s3://crabby-images/aaece/aaece43eb3bca500b46e8da11ad39fbeb9e46731" alt="Create a new dashboard on the <b>ThingsBoard Server</b>. Click the <b>"Dashboard details"</b> icon to view details;"
data:image/s3,"s3://crabby-images/351c1/351c1d337278bbc2dcd6256341dd9960e37c3b61" alt="Click the <b>"Manage owner and groups"</b> button;"
data:image/s3,"s3://crabby-images/e5585/e5585ca9606ae1cd3f8573ffe163afca85c88560" alt="Now, create a new <b>dashboard group</b> and add the previously created dashboard to it. Enter a name for the new dashboard group (for example, "Edge Dashboard Group") in the <b>"Groups"</b> field, and click the <b>"Create a new one!"</b> link."
data:image/s3,"s3://crabby-images/8103f/8103f5ea13dea2c8cb3ed885d669671ee59752d3" alt="In the <b>"Add entity group"</b> pop-up window, click the <b>"Add"</b> button."
data:image/s3,"s3://crabby-images/21b57/21b5766620b4f647ef084164ecc43f97e8c228b2" alt="The <b>"Edge Dashboard Group"</b> appears in the <b>"Groups"</b> field. Click the <b>"Update"</b> button."
data:image/s3,"s3://crabby-images/fe044/fe04444ff34337e908a15678b26bc1a01fa9fea6" alt="The newly created group is now available in the <b>"Groups"</b> column."
data:image/s3,"s3://crabby-images/adfd3/adfd342a81e5341808cf4db267bcb74daa602afe" alt="Go to the <b>Edge management > Instances</b> section. Click the <b>"Manage edge dashboard groups"</b> icon of the instance in question."
data:image/s3,"s3://crabby-images/b3e8e/b3e8e66df1ae8e29478562c12c0ff88f89f32270" alt="On the <b>Edge Dashboard Groups</b> page, you will see all the dashboard groups that are already assigned to this <b>Edge</b>. To assign another dashboard group, click the <b>"+"</b> icon and select "Edge Dashboard Group" from the drop-down-menu. Click the <b>"Assign"</b> button."
To confirm that assigned entity is available on the Edge, open the EDGE_URL and go to the corresponding entity section:
- Go to the Dashboards section and open the dashboard you have created on the ThingsBoard Professional Edition Server
- Verify that these are the same widgets that you have added on the Cloud.
data:image/s3,"s3://crabby-images/eab92/eab9249faa07c4c82736b5de0634701145c0dd65" alt="Go to the <b>Dashboards</b> section and open the dashboard you have created on the <b>ThingsBoard Professional Edition Server</b>"
data:image/s3,"s3://crabby-images/6a212/6a2120303a223b1824278b7fe1e77f4ab0ff5185" alt="Verify that these are the same widgets that you have added on the Cloud."
Your Feedback
Congratulations! You have successfully completed the initial configuration steps for ThingsBoard Edge. Now you can send new telemetry readings and they will appear on the dashboard immediately.
Help us improve by providing your feedback at GitHub/Issues or through the “Contact us” form. We would also greatly appreciate it if you could star our project on GitHub!
Next steps
-
Installation guides - Learn how to setup ThingsBoard Edge on various available operating systems and connect to ThingsBoard Server.
-
Edge Rule Engine:
-
Rule Chain Templates - Learn how to use ThingsBoard Edge Rule Chain Templates.
-
Provision Rule Chains from cloud to edge - Learn how to provision edge rule chains from cloud to edge.
-
- Security:
- gRPC over SSL/TLS - Learn how to configure gRPC over SSL/TLS for communication between edge and cloud.
-
Features:
-
Edge Status - Learn about Edge Status page on ThingsBoard Edge.
-
Cloud Events - Learn about Cloud Events page on ThingsBoard Edge.
-
-
Use cases:
-
Manage alarms and RPC requests on edge devices - This guide will show how to generate local alarms on the edge and send RPC requests to devices connected to edge:
-
Data filtering and traffic reduce - This guide will show how to send to cloud from edge only filterd amount of device data:
-
- Roadmap - ThingsBoard Edge roadmap.