Skip to content

Latest commit

 

History

History
205 lines (174 loc) · 14.8 KB

README.md

File metadata and controls

205 lines (174 loc) · 14.8 KB

IoT Edge Demos

This repo contains several projects that are part of an IoT Edge demo solution.

Demo scenario

The demo scenario is built around a big Shopping Mall. The manager of the mall wants to know at all times how busy the mall is. In order to get the necessary information to determine this, each shop entry is fitted with a motion-sensor. This sensor can detect whether a customer is entering the shop or exiting the shop. Every sensor sends an event to a central system every time this happens. These events are used to build a nice graphical overview of the traffic going in and out of all the shops:

At the top of the dashboard you can see an overview of all the shops (on level 1). Every shop's sensor is indicated with a blue circle. If a customer enters or exists the shop, the sensor indicator will flash green or red accordingly.

Directly below the map you can see a graph that shows how crowded every shop is. Every shop has a certain maximum capacity. The bar indicates how much of the this capacity is in use.

The bottom graph will show the progression of the total amount of customers in the mall over time.

High-level overview of the solution

The solution for the Mall Management system is created using the following Azure services:

Azure Service Description
Azure IoT Hub This is the central management and communications hub. IoT Edge devices connect to this hub.
Azure IoT Edge This is used for running sensor software on IoT Edge devices and communicate events to the IoT Hub.
Azure Function This is used to ingest all events sent to the IoT Hub and publish these to a SignalR hub.
Azure SignalR Service This is used to publish all messages received from the Azure Function to all SignalR clients connected to the SignalR hub.

The visual dashboard is built using ASP.NET Core

The solution works as follows:

  1. Every door-sensor is simulated by a single IoT Edge module running on an IoT Edge device. Every sensor simulates customers going in or out of the shop at random intervals. The 39 sensors are devided into 3 groups of 13 with each group running on a separate device.
  2. For every simulated customer, the Edge Module sends a message to the IoT Hub.
  3. The event triggers an Azure Function app that reacts to events in the default IoT Hub event-queue.
  4. The function app creates a message and sends it to the SignalR hub.
  5. The Visual Dashboard web-app gets the necessary credentials to connect to the SignalR service by calling the SignalRInfo Azure Function and connects to the hub.
  6. The dashboard starts receiving messages from the SignalR hub.
  7. With every incoming event, the dashboard updates the map and the graphs.

Running the solution

If you want to run this solution yourself, execute the steps described below.

1. Satisfy the prerequisites

  1. Fork and clone this Git repository.

    For step 2 - 6, don't wait until a step is copletely finished, but as soon as the service is deploying, go to the next step.

  2. Create an Container Registry in Azure.

    • Make sure you enable Admin user-access to the registry.
    • Choose the Basic SKU.
  3. Create an IoT Hub in Azure.

    • Choose the S1: Standard tier to enable the IoT Edge feature. (You can also choose the F1: Free tier, but this allows you to send a maximum of 8000 messages per day. For this workshop, this is probably enough. But if you wantexperiment some more with the solution, choose the S1 tier.)
  4. Create a simulated edge device VM in Azure.

    • Search IoT Edge on Ubuntu in the Azure Marketplace. You will find a template for VM with Ubuntu 16.04 LTS with the IoT Edge runtime pre-installed.
    • Create a VM based on this template.
    • Choose the Standard B1ms size VM.
    • You don't have to open any network ports or enable SSH / RDP access to the VM.
    • Choose the cheapest disk configuration and size possible.
  5. Create a SignalR service in Azure.

    • Choose the Free pricing tier.
    • Choose the Serverless Service Mode.
  6. Create a Function App in Azure.

    • Choose .NET Core as the runtime-stack.
    • Choose Windows as OS.
    • Choose the Consumption Plan hosting plan.
  7. Add a consumer-group to the built-in events endpoint of the IoT Hub you just created:

    • Open the Built-in endpoints blade of the IoT Hub.
    • Click in the Create new consumer group text-box and type the name of the group: mallmanagement.
    • Leave the text-box (press tab) in order to submit the change.
  8. Collect the necessary secrets from the created Azure services and keep them somewhere for later.

    • Open the Container Registry page, go to the Access Keys blade and copy the user-name and password for this registry.
    • Open the IoT Hub page, go to the Built-in endpoints blade and copy the Event Hub-compatible endpoint connection-string.
    • Open the SignalR page, go to the Keys blade and copy the connection-string.
  9. Install Docker for desktop.

  10. Install LTS version of the .NET Core SDK.

  11. Install Visual Studio Code.

  12. Install the C# extension for VS Code.

  13. Install the Azure IoT Tools extension for VS Code.

  14. Install version 2.x of the Azure Functions Core Tools.

  15. Install the Azure Functions extensions for VS Code.

  16. Open the iot-edge-demos.code-workspace file in the repository using Visual Studio Code.

  17. Make sure you are signed into your Azure subscription from Visual Studio Code so you can access your Azure resources:

    • Press the short-cut key Ctrl-Shift-P to open the command-list.
    • Type Azure: Sign in and select the command from the list.
    • Login with your credentials.

Once you have satisfied the prerequisites above, you can dive in and start the solution. Execute the following steps:

For all the following steps I assume that you have opened the iot-edge-demos.code-workspace file in the repository using Visual Studio Code.

2. Deploy the Azure Function app

  1. Open the Azure Portal and select the Function App you created earlier.
  2. Add 2 connection strings to the app settings:
    • Click the Configuration option:
    • Add an application setting AzureSignalRConnectionString with as value the connection-string to the SignalR service you copied earlier.
    • Add an application setting IOTHUB_EVENTS with as value the Event Hub-compatible endpoint connection-string you copied earlier.
    • Remember to click Save.
  3. Configure CORS for your Function App:
    • In the Function App, select the Platform features tab and click the CORS link:
    • Remove all the existing rules and add a new rule that allows *:
    • Click Save.
  4. Deploy the function app from VS Code:
    • Right click the Functions folder in VS Code and select the Deploy to Function App... option.
    • Select your Function App.
    • Check the output window for any errors.

3. Connect to your IoT Hub

In order to manage your IoT Hub from VS Code, you need to connect to it:

  1. Select your IoT Hub in Visual Studio Code.
    • Press the short-cut key Ctrl-Shift-P to open the command-list.
    • Type Azure IoT Hub: Select IoT Hub and select the command from the list.
    • Select the subscription that contains the IoT Hub you created earlier.
    • Select your IoT Hub.
  2. Display the Azure IoT Hub Devices explorer in the sidebar (if not already visible):
    • Click the View menu.
    • Select the Open View... option.
    • Type IoT and select the Azure IoT Hub Devices view.

4. Build and push the IoT Edge module image

In this part you will build the IoT Edge solution and push the resulting module Docker image to your container registry:

  1. Make sure your Docker for Desktop is running.
  2. Expand the EdgeModules project in VS Code.
  3. Configure the container registry credentials:
    • Rename the .env.sample file to .env.
    • Open the file.
    • Fill in the variables:
      • The address of your container registry (e.g. mycr.azurecr.io)
      • The user name for this registry.
      • The password for this registry.
  4. Log-in Docker to the container registry by running the following command from the terminal: docker login <your_acr>.azurecr.io. Use the same user name and password from the .env file.
  5. In the EdgeModules/modules/SensorModule/ directory, open the module.json file and update the value for repository with the name of your own Azure Container Registry, e.g. mycr.azurecr.io/sensormodule.
  6. Select the target platform for your device:
    • Press the short-cut key Ctrl-Shift-P to open the command-list.
    • Select command IoT Edge: Set default Target Platform for Edge Solution.
    • Select the target platform amd64 as we want to use the earlier deployed Linux VM as the Edge device. Alternatively, you can use arm32v7 for a Raspberry Pi, or windows-amd64 for a Windows host.
    • You can also see a shortcut in the status-bar of VS Code you can use to change the target platform:
  7. Right click the deployment.template.json file and select the option Build and Push IoT Edge Solution.
  8. Check the output window for any errors.
    • If you see an error about authentication, make sure you're logged into your container registry. You can do this by opening a terminal window and issuing the command docker login <registry address>. You will be prompted for a user name and password.
    • If you see an error about not being able to contact the Docker daemon, your Docker for Desktop is probably not running (correctly). Start it (or restart it if it is running).
  9. Check out whether the image was pushed correctly by opening the container registry and checking whether there is a repository named sensormodule with an image in it tagged with the correct version (as specified in the module.json) and the selected platform (e.g. 1.5-amd64).

5. Configure the Dashboard web-app

In order for the dashboard app to connect to the SignalR service, you need the service endpoint URL and a valid access token. The SignalRInfo function in the Azure Funtions app can be called over HTTP to retrieve this connection-information. To call this function, you need to authenticate with the function-key. You need to configure the web-app so it can authenticate to the function:

  1. Expand the MallDashboard folder in VS Code.
  2. Configure the SignalRInfo function credentials:
    • Expand the /js folder.
    • Rename the secrets.sample.js file to secrets.js.
    • Open the file.
    • Fill in the variables:
      • The name of your Function App.
      • The default function-key of the SignalRInfo function. You can get this key by opening the Function App in the Azure Portal, selecting the SignalRInfo function and clicking the Manage option:

6. Start the dashboard

In order to see the telemetry from the sensor modules, you need to start the dashboard:

  1. Configure the web-app to be the start-up project:
    • Go to the Debug window in the side-bar.
    • Click the selection arrow in the launch-configuration drop-down.
    • Select the configuration .NET Core Launch (web) (MallDashboard):
  2. Click the start button or press F5.
  3. The web-app should start and automatically open an browser window. If this does not happen, open a browser and navigate to https://localhost:5001.

7. Add an edge device

Now you can add your Edge device to the IoT Hub (we will use the VM that you created in the prerequisites):

  1. Click the ellipses button of the Azure IoT Hub Devices explorer in the sidebar, and select Create IoT Edge Device:
  2. Enter a name for your device (e.g. device01) and press enter to confirm.
  3. Watch the output window and wait until you see the results:
  4. Copy the connection-string from the result window to the clipboard. (You can also get the device connection-string by right-clicking in the device in the Azure IoT Hub Devices explorer in the sidebar and selecting Copy Device Connection String).
  5. Configure the VM to connect to the IoT Hub using the connection-string:
    • Open the Azure portal and go to the blade for the VM that you created as part of the prerequisites.
    • Click the Run command option in the Operations section of the blade's menu.
    • Click the Run Shell Script command.
    • Type the following command in the Linux Shell Script window: /etc/iotedge/configedge.sh "<connection-string>" and execute it by clicking the Run button.
    • Do not close the blade and wait for the result to show in the result window.
  6. Go to VS Code and expand the modules folder of the newly created device in the Azure IoT Hub Devices explorer in the sidebar. Hit refresh a couple of times and after some time, you should see the $edgeAgent and $edgeHub modules up & running:

8. Deploy the sensor modules to your device

Now you're going to deploy the sensor modules to the IoT Edge device:

  1. Make sure you have a config folder in the EdgeModules project with a deployment.amd64.json file. If not, make sure you have built and pushed your module image (see description above).
  2. Open the file properties-012.json in the DoorSensorProperties folder.
  3. Copy everything from this file except the outer most curly-braces.
  4. Open the deployment.amd64.json file in the config folder in the EdgeModules project.
  5. Paste the copied properties in the files below the properties for the $edgeHub module (don't forget to add a comma after the $edgeHub property block):
  6. Save the file and right-click on it in the VS Code file explorer.
  7. Select the option Create Deployment for Single Device.
  8. Select the device you just added and check the output window for the results.
  9. After some time, you should see sensor telemetry coming in on the dashboard.

If you start a device while your dashboard is not running, take into consideration that messages sent from the device are kept for some time in the IoT Hub's events queue. So when you start your dashboard after the device has been running for some time (even when it is currently not running), you will see all the messages from the queue coming in really fast. So always start your dashboard first and then start your device.