This quickstart will run a container, create a solution, setup Azure resources, build and deploy modules to your device, setup and start the IoT Edge simulator, monitor messages flowing into IoT Hub, and finally deploy to the IoT Edge runtime.
At the end of this quickstart, you should have the following:
- Development environment.
- IoT Hub deployed in your Azure subscription.
- A directory with the IoT edge deployment manifest, .env file with the environment variables needed for the
iotedgedev
tool, and the source file of a custom IoT edge module (filtermodule
). - The docker image of the
filtermodule
. - Deploying the IoT edge modules defined in the manifest on a VM or IoT Edge simulator.
- Monitoring the messages sent to the IoT Hub.
- Cleaning up the docker containers and images.
- Docker (see Install Docker docs for details) and add user to
docker
Unix group (see documentation).
-
Setup your environment
There are three options to setup your environment:
- Setup the development environment manually. Please follow the Manual Development Machine Setup Wiki.
- Starting the devcontainer in VS Code (see Developing inside a Container for steps on how to do so).
- Starting the devcontainer with Docker. Please follow the Run the IoT Edge Dev Container with Docker docs.
-
Initialize IoT Edge solution and setup Azure resources.
iotedgedev init <foldername>
iotedgedev init
will create a solution in a new folder and setup your Azure IoT Hub in a single command. The solution comes with a default C# module namedfiltermodule
.More information
- You will see structure of current folder like below:
│ .env │ .gitignore │ deployment.debug.template.json │ deployment.template.json │ ├─.vscode │ launch.json │ └─modules └─filtermodule │ .gitignore │ Dockerfile.amd64 │ Dockerfile.amd64.debug │ Dockerfile.arm32v7 │ Dockerfile.windows-amd64 │ filtermodule.csproj │ module.json │ Program.cs
-
Open
.env
file, you will see theIOTHUB_CONNECTION_STRING
andDEVICE_CONNECTION_STRING
environment variables filled correctly. -
Open
deployment.template.json
file.- You will see below section in the modules section:
"filtermodule": { "version": "1.0", "type": "docker", "status": "running", "restartPolicy": "always", "settings": { "image": "${MODULES.filtermodule}", "createOptions": {} } }
- Two default routes are added:
"routes": { "sensorTofiltermodule": "FROM /messages/modules/tempSensor/outputs/temperatureOutput INTO BrokeredEndpoint(\"/modules/filtermodule/inputs/input1\")", "filtermoduleToIoTHub": "FROM /messages/modules/filtermodule/outputs/* INTO $upstream" }
-
You will see privacy statement like below:
Welcome to iotedgedev! ------------------------- Telemetry --------- The iotedgedev collects usage data in order to improve your experience. The data is anonymous and does not include commandline argument values. The data is collected by Microsoft. You can change your telemetry settings by updating 'collect_telemetry' to 'no' in ~/.iotedgedev/setting.ini
-
Build IoT Edge module images.
iotedgedev build
This step will build user modules in deployment.template.json targeting amd64 platform.
More information
- You will see a "BUILD COMPLETE" for each module and no error messages in the terminal output.
- Open
config/deployment.amd64.json
file, you will see the module image placeholders expanded correctly. - Run
sudo docker image ls
, you will see the module images you just built.
-
Run IoT Edge modules.
Edge modules can be started in two different ways using
iotedgedev
:- Deploying them on a VM; please find the steps to do so in Set up and start modules on a virtual machine;
- or in your own development machine using the
iotedgedev
simulator; please follow Set up and start the IoT Edge Simulator.
-
Monitor messages sent from device to IoT Hub.
iotedgedev monitor
More information
- You will see your expected messages sending to IoT Hub
- Stopping the monitor doesn't stop the simulator. It will continue running until it is explicitely stopped using
iotedgedev stop
and at that time all containers used by the simulator will be cleaned up.
-
Stop docker containers and remove images.
# stop containers started by the simulator iotedgedev stop # remove stopped containers iotedgedev docker clean -c # remove docker images iotedgedev docker clean -