The IoT Edge Dev Tool greatly simplifies Azure IoT Edge development down to simple commands driven by environment variables.
- It gets you started with IoT Edge development with the IoT Edge Dev Container and IoT Edge solution scaffolding that contains a default module and all the required configuration files.
- It speeds up your inner-loop dev (dev, debug, test) by reducing multi-step build & deploy processes into one-line CLI commands as well as drives your outer-loop CI/CD pipeline. You can use all the same commands in both stages of your development life-cycle.
- This repo is based on Azure IoT Edge Dev Github
For the absolute fastest way to get started with IoT Edge Dev, please see the Quickstart section below.
For a more detailed overview of IoT Edge Dev Tool including setup and commands, please see the Wiki.
This quickstart will run a vscode devcontainer, 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.
The only thing you need to install is Docker. All of the other dev dependencies are included in the container.
-
Pre requisites
- Docker Desktop
- VSCode with Remote-containers extention installed
-
Clone this repo to a local folder
- Just use the regular way to repo your folder.
-
Open VSCode
- Open VSCode in the cloned folder
- VSCode will detect the devcontainer definition and ask to reopen in devcontainer, press accept
- Copy the
.env.tmp
file as.env
The solution comes with a default python module named
filterModule
More information
- You will see structure of current folder like below:
│ .env.tmp │ .gitignore │ deployment.debug.template.json │ deployment.template.json │ ├─.vscode │ launch.json │ └─modules └─filtermodule │ .gitignore │ Dockerfile.amd64 │ Dockerfile.amd64.debug │ Dockerfile.arm32v7 │ Dockerfile.arm32v7.debug │ Dockerfile.arm64v8 │ Dockerfile.arm64v8.debug │ main.py | module.json │ requirements.txt
-
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" }
-
Initialize IoT Edge solution and setup Azure resources
iotedgedev iothub setup
iotedgedev iothub setup
will setup your Azure IoT Hub in a single command.- Open
.env
file, you will see theIOTHUB_CONNECTION_STRING
andDEVICE_CONNECTION_STRING
environment variables filled correctly.
- Open
-
Build IoT Edge module images
sudo 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.
-
Setup and start the IoT Edge Simulator to run the solution
sudo iotedgedev start --setup --file config/deployment.amd64.json
More information
- You will see an "IoT Edge Simulator has been started in solution mode." message at the end of the terminal output
- Run
sudo docker ps
, you will see your modules running as well as an edgeHubDev container
-
Monitor messages sent from IoT Edge Simulator to IoT Hub
iotedgedev monitor
More information
- You will see your expected messages sending to IoT Hub
Please refer to the Wiki for details on setup, usage, and troubleshooting.
This project collects usage data and sends it to Microsoft to help improve our products and services. Read our privacy statement to learn more.
If you don’t wish to send usage data to Microsoft, you can change your telemetry settings by updating collect_telemetry
to no
in ~/.iotedgedev/settings.ini
.
This project welcomes contributions and suggestions. Please refer to the Contributing file for details on contributing changes.
Most contributions require you to agree to a Contributor License Agreement (CLA) declaring that you have the right to, and actually do, grant us the rights to use your contribution. For details, visit https://cla.microsoft.com.
When you submit a pull request, a CLA-bot will automatically determine whether you need to provide a CLA and decorate the PR appropriately (e.g., label, comment). Simply follow the instructions provided by the bot. You will only need to do this once across all repositories using our CLA.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact [email protected] with any additional questions or comments.