An Azure Storage container without Private Endpoint enabled.
If you're not sure if Private Endpoint is enabled, go to Private Link Center, select "Private endpoints" on the left, then look for your Azure Storage account name in the "Resources" column.
Sign in to the Azure CLI by using the az login command.
Run az version to find the version and dependent libraries that are installed. To upgrade to the latest version, run az upgrade.
When prompted, install Azure CLI extensions on first use. The commands in this article use the azure-iot extension. Run az extension update --name azure-iot to make sure you're using the latest version of the extension.
Tip
The Azure CLI commands in this article use the backslash \ character for line continuation so that the command arguments are easier to read. This syntax works in Bash environments. If you're running these commands in PowerShell, replace each backslash with a backtick ```, or remove them entirely.
Import an update
This section shows how to import an update using either the Azure portal or the Azure CLI. You can also use the Device Update for IoT Hub APIs to import an update instead.
To import an update, you first upload the update files and import manifest into an Azure Storage container. Then, you import the update from Azure Storage into Device Update for IoT Hub, where it will be stored for you to deploy to devices.
In the Azure portal, navigate to your IoT Hub with Device Update.
On the left-hand side of the page, select Updates under Device Management.
Select the Updates tab from the list of tabs across the top of the screen.
Select + Import a new update below the Available Updates header.
Select + Select from storage container. The Storage accounts UI is shown. Select an existing account, or create an account using + Storage account. This account is used for a container to stage your updates for import. The account should not have both public and private endpoints enabled at the same time.
Once you've selected a Storage account, the Containers UI is shown. Select an existing container, or create a container using + Container. This container is used to stage your update files for importing
We recommend that you use a new container each time you import an update. Always using new containers helps you to avoid accidentally importing files from previous updates. If you don't use a new container, be sure to delete any files from the existing container before you complete this step.
In your container, select Upload. The Upload UI is shown.
Select the folder icon on the right side of the Files section under the Upload blob header. Use the file picker to navigate to the location of your update files and import manifest, select all of the files, then select Open. You can hold the Shift key and click to multi-select files.
When you've selected all your update files, select Upload.
Select the uploaded files to designate them to be imported. Then select the Select button to return to the Import update page.
On the Import update page, review the files to be imported. Then select Import update to start the import process. To resolve any errors, see Proxy update troubleshooting.
The import process begins, and the screen switches to the Import History section. Select Refresh to view progress until the import process completes (depending on the size of the update, the process might complete in a few minutes but could take longer).
When the Status column indicates that the import has succeeded, select the Available Updates header. You should see your imported update in the list now.
The az iot du update stage command handles the prerequisite steps of importing an update, including uploading the update files into a target storage container. An optional flag also lets this command automatically import the files after they're prepared. Otherwise, the az iot du update import command completes the process.
The stage command takes the following arguments:
--account: The Device Update account name.
--instance: The Device Update instance name.
--manifest-path: The file path to the import manifest that should be staged.
--storage-account: The name of the storage account to stage the update.
--storage-container: The name of the container within the selected storage account to stage the update.
--overwrite: Optional flag that indicates whether to overwrite existing blobs in the storage container if there's a conflict.
--then-import: Optional flag that indicates whether the update should be imported to Device Update after it's staged.
az iot du update stage \
--account <Replace with your Device Update account name> \
--instance <Replace with your Device Update instance name> \
--manifest-path <Replace with the full path to your import manifest> \
--storage-account <Replace with your Storage account name> \
--storage-container <Replace with your container name> \
--overwrite --then-import
If you don't use the --then-import flag, the output of the stage command includes a prompt to run az iot du update import, including pre-populated arguments.
Use az iot du update list to verify that your update or updates were successfully imported.
az iot du update list \
--account <Replace with your Device Update account name> \
--instance <Replace with your Device Update instance name> \
-o table
If you're importing using APIs instead
You can also import an update programmatically by:
Update files and import manifest must be uploaded to an Azure Storage Blob container for staging. To import the staged files, provide the blob URL, or shared access signature (SAS) for private blobs, to the Device Update API. If using a SAS, be sure to provide an expiration window of three hours or more
Tip
To upload large update files to Azure Storage Blob container, you may use one of the following for better performance:
Build end-to-end solutions in Microsoft Azure to create Azure Functions, implement and manage web apps, develop solutions utilizing Azure storage, and more.