Azure IoT Edge on CentOS Connnected to IoT Central
This tutorial demonstrates a scenario of IoT Edge runtime running on CentOS 7.X and provisioned and managed from IoT Central. It requires a device or VM running CentOS 7.X and an IoT Central App to provision and manage it. This tutorial will use an CentOS 7.5 deployed on Azure.
IoT Edge Support lists Azure IoT Edge supported systems.
In this tutorial, you learn how to:
- Create a device template for an IoT Edge device
- Create an IoT Edge device in IoT Central
- Deploy a simulated IoT Edge device to a CentOS VM
Prerequisites
Complete the Create an Azure IoT Central application quickstart to create an IoT Central application using the Custom app > Custom application template.
To complete the steps in this tutorial, you need an active Azure subscription.
If you don’t have an Azure subscription, create a free account before you begin.
Download the IoT Edge manifest file from GitHub. Right-click on the following link and then select Save link as: EnvironmentalSensorManifest.json
Create device template
In this section, you create an IoT Central device template for an IoT Edge device. You import an IoT Edge manifest to get started, and then modify the template to add telemetry definitions and views:
Import manifest to create template
To create a device template from an IoT Edge manifest:
-
In your IoT Central application, navigate to Device templates and select + New.
-
On the Select template type page, select the Azure IoT Edge tile. Then select Next: Customize.
-
On the Upload an Azure IoT Edge deployment manifest page, enter Environmental Sensor Edge Device as the device template name. Then select Browse to upload the EnvironmentalSensorManifest.json you downloaded previously. Then select Next: Review.
-
On the Review page, select Create.
-
Select the Manage interface in the SimulatedTemperatureSensor module to view the two properties defined in the manifest:
Add telemetry to manifest
An IoT Edge manifest doesn’t define the telemetry a module sends. You add the telemetry definitions to the device template in IoT Central. The SimulatedTemperatureSensor module sends telemetry messages that look like the following JSON:
{
"machine": {
"temperature": 75.0,
"pressure": 40.2
},
"ambient": {
"temperature": 23.0,
"humidity": 30.0
},
"timeCreated": ""
}
To add the telemetry definitions to the device template:
-
Select the Manage interface in the Environmental Sensor Edge Device template.
-
Select + Add capability. Enter machine as the Display name and make sure that the Capability type is Telemetry.
-
Select Object as the schema type, and then select Define. On the object definition page, add temperature and pressure as attributes of type Double and then select Apply.
-
Select + Add capability. Enter ambient as the Display name and make sure that the Capability type is Telemetry.
-
Select Object as the schema type, and then select Define. On the object definition page, add temperature and humidity as attributes of type Double and then select Apply.
-
Select + Add capability. Enter timeCreated as the Display name and make sure that the Capability type is Telemetry.
-
Select DateTime as the schema type.
-
Select Save to update the template.
The Manage interface now includes the machine, ambient, and timeCreated telemetry types:
Add views to template
The device template doesn’t yet have a view that lets an operator see the telemetry from the IoT Edge device. To add a view to the device template:
-
Select Views in the Environmental Sensor Edge Device template.
-
On the Select to add a new view page, select the Visualizing the device tile.
-
Change the view name to View IoT Edge device telemetry.
-
Select the ambient and machine telemetry types. Then select Add tile.
-
Select Save to save the View IoT Edge device telemetry view.
Publish the template
Before you can add a device that uses the Environmental Sensor Edge Device template, you must publish the template.
Navigate to the Environmental Sensor Edge Device template and select Publish. On the Publish this device template to the application panel, select Publish to publish the template:
Add IoT Edge device
Now you’ve published the Environmental Sensor Edge Device template, you can add a device to your IoT Central application:
-
In your IoT Central application, navigate to the Devices page and select Environmental Sensor Edge Device in the list of available templates.
-
Select + New to add a new device from the template. On the Create new device page, select Create.
You now have a new device with the status Registered:
Get the device credentials
When you deploy the IoT Edge device later in this tutorial, you need the credentials that allow the device to connect to your IoT Central application. The get the device credentials:
-
On the Device page, select the device you created.
-
Select Connect.
-
On the Device connection page, make a note of the ID Scope, the Device ID, and the Primary Key. You use these values later.
-
Select Close.
You’ve now finished configuring your IoT Central application to enable an IoT Edge device to connect.
Deploy an IoT Edge device on CentOS
In this tutorial, you use a CentOS VM, created on Azure to simulate an IoT Edge device.
Below are the steps to install a CentOS VM and install IoT Edge runtime.
-
Go To Azure Portal
-
You can search for CentOS 7.5 VM from marketplace and click Create button to install CentOS 7.5 VM
-
Enter valid information and click Review + create
-
Go To newly created CentOS VM and click on serial console and enter your login and password.
- Check the OS and Version on the VM, type
$ uname -a
-
Install Moby engine. As of the date this tutorial was created following is the latest package. To get the latest package go to Moby Engine Packages
$ sudo yum install https://packages.microsoft.com/centos/7/prod/moby-engine-3.0.13%2Bazure-0.x86_64.rpm
Install CLI
$ sudo yum install https://packages.microsoft.com/centos/7/prod/moby-cli-3.0.13%2Bazure-0.x86_64.rpm
- Install dependencies
$ sudo yum install http://ftp.altlinux.org/pub/distributions/ALTLinux/Sisyphus/x86_64/RPMS.classic/libcrypto10-1.0.2r-alt3.x86_64.rpm
- Install IoT Edge Runtime
$ sudo yum install https://github.com/Azure/azure-iotedge/releases/download/1.0.9.3/libiothsm-std_1.0.9.3-1.el7.x86_64.rpm $ sudo rpm -Uhv https://github.com/Azure/azure-iotedge/releases/download/1.0.9.3/iotedge-1.0.9.3-1.el7.x86_64.rpm
-
Edit /etc/iotedge/config.yaml to update Device provisioning service properties to provision the device
Comment out manual configuration portion on the config.yaml
Uncomment out device provisioning service with symmetric key and update scope id, registration id with your device id from IoT Central and symmetric key which you got from the Get the device credentials section of this tutorial
- Restart Edge and list edge modules
$ sudo systemctl restart iotedge $ sudo iotedge list
-
Go To Device Details page on IoT Central and you will see telemetry flowing from your device