az vm
Note
This command group has commands that are defined in both Azure CLI and at least one extension. Install each extension to benefit from its extended capabilities. Learn more about extensions.
Manage Linux or Windows virtual machines.
Commands
| Name | Description | Type | Status | 
|---|---|---|---|
| az vm aem | Manage Azure Enhanced Monitoring Extension for SAP. | Extension | GA | 
| az vm aem delete | Remove Azure Enhanced Monitoring Extension. | Extension | GA | 
| az vm aem set | Configure Azure Enhanced Monitoring Extension. | Extension | GA | 
| az vm aem verify | Verify Azure Enhanced Monitoring Extensions configured correctly. | Extension | GA | 
| az vm application | Manage applications for VM. | Core | GA | 
| az vm application list | List applications for VM. | Core | GA | 
| az vm application set | Set applications for VM. | Core | GA | 
| az vm assess-patches | Assess patches on a VM. | Core | GA | 
| az vm auto-shutdown | Manage auto-shutdown for VM. | Core | GA | 
| az vm availability-set | Group resources into availability sets. | Core | GA | 
| az vm availability-set cancel-migration-to-vmss | Cancel the migration operation on an Availability Set. | Core | GA | 
| az vm availability-set convert | Convert an Azure Availability Set to contain VMs with managed disks. | Core | GA | 
| az vm availability-set convert-to-vmss | Create a new Flexible Virtual Machine Scale Set and migrate all the Virtual Machines in the Availability Set. This does not trigger a downtime on the Virtual Machines. | Core | GA | 
| az vm availability-set create | Create an Azure Availability Set. | Core | GA | 
| az vm availability-set delete | Delete an availability set. | Core | GA | 
| az vm availability-set list | List all availability sets in a subscription. | Core | GA | 
| az vm availability-set list-sizes | List all available virtual machine sizes that can be used to create a new virtual machine in an existing availability set. | Core | GA | 
| az vm availability-set show | Get information about an availability set. | Core | GA | 
| az vm availability-set start-migration-to-vmss | Start migration operation on an Availability Set to move its Virtual Machines to a Virtual Machine Scale Set. This should be followed by a migrate operation on each Virtual Machine that triggers a downtime on the Virtual Machine. | Core | GA | 
| az vm availability-set update | Update an Azure Availability Set. | Core | GA | 
| az vm availability-set validate-migration-to-vmss | Validate that the Virtual Machines in the Availability Set can be migrated to the provided Virtual Machine Scale Set. | Core | GA | 
| az vm boot-diagnostics | Troubleshoot the startup of an Azure Virtual Machine. Use this feature to troubleshoot boot failures for custom or platform images. | Core | GA | 
| az vm boot-diagnostics disable | Disable the boot diagnostics on a VM. | Core | GA | 
| az vm boot-diagnostics enable | Enable the boot diagnostics on a VM. | Core | GA | 
| az vm boot-diagnostics get-boot-log | Get the boot diagnostics log from a VM. | Core | GA | 
| az vm boot-diagnostics get-boot-log-uris | Get SAS URIs for a virtual machine's boot diagnostic. | Core | GA | 
| az vm capture | Capture information for a stopped VM. | Core | GA | 
| az vm convert | Convert a VM with unmanaged disks to use managed disks. | Core | GA | 
| az vm create | Create an Azure Virtual Machine. | Core | GA | 
| az vm deallocate | Deallocate a VM so that computing resources are no longer allocated (charges no longer apply). The status will change from 'Stopped' to 'Stopped (Deallocated)'. | Core | GA | 
| az vm delete | Delete operation to delete a virtual machine. | Core | GA | 
| az vm diagnostics | Configure the Azure Virtual Machine diagnostics extension. | Core | GA | 
| az vm diagnostics get-default-config | Get the default configuration settings for a VM. | Core | GA | 
| az vm diagnostics set | Configure the Azure VM diagnostics extension. | Core | GA | 
| az vm disk | Manage the managed data disks attached to a VM. | Core | GA | 
| az vm disk attach | Attach a managed persistent disk to a VM. | Core | GA | 
| az vm disk detach | Detach a managed disk from a VM. | Core | GA | 
| az vm encryption | Manage encryption of VM disks. | Core | GA | 
| az vm encryption disable | Disable disk encryption on the OS disk and/or data disks. Decrypt mounted disks. | Core | GA | 
| az vm encryption enable | Enable disk encryption on the OS disk and/or data disks. Encrypt mounted disks. | Core | GA | 
| az vm encryption show | Show encryption status. | Core | GA | 
| az vm extension | Manage extensions on VMs. | Core | GA | 
| az vm extension delete | Delete operation to delete the extension. | Core | GA | 
| az vm extension image | Find the available VM extensions for a subscription and region. | Core | GA | 
| az vm extension image list | List the information on available extensions. | Core | GA | 
| az vm extension image list-names | List the names of available extensions. | Core | GA | 
| az vm extension image list-versions | List the versions for available extensions. | Core | GA | 
| az vm extension image show | Display information for an extension. | Core | GA | 
| az vm extension list | List the extensions attached to a VM. | Core | GA | 
| az vm extension set | Set extensions for a VM. | Core | GA | 
| az vm extension show | Display information about extensions attached to a VM. | Core | GA | 
| az vm extension wait | Place the CLI in a waiting state until a condition is met. | Core | GA | 
| az vm generalize | Mark a VM as generalized, allowing it to be imaged for multiple deployments. | Core | GA | 
| az vm get-instance-view | Get instance information about a VM. | Core | GA | 
| az vm host | Manage Dedicated Hosts for Virtual Machines. | Core | GA | 
| az vm host create | Create a dedicated host. | Core | GA | 
| az vm host delete | Delete a dedicated host. | Core | GA | 
| az vm host get-instance-view | Get instance information about a dedicated host. | Core | GA | 
| az vm host group | Manage Dedicated Host Groups. | Core | GA | 
| az vm host group create | Create a dedicated host group. | Core | GA | 
| az vm host group delete | Delete a dedicated host group. | Core | GA | 
| az vm host group get-instance-view | Get instance view of a dedicated host group. | Core | GA | 
| az vm host group list | List dedicated host groups. | Core | GA | 
| az vm host group show | Get the details of a dedicated host group. | Core | GA | 
| az vm host group update | Update a dedicated host group. | Core | GA | 
| az vm host list | List dedicated hosts. | Core | GA | 
| az vm host list-resize-options | List all available dedicated host sizes to which the specified dedicated host can be resized. NOTE: The dedicated host sizes provided can be used to only scale up the existing dedicated host. | Core | GA | 
| az vm host redeploy | Redeploy the dedicated host. | Core | GA | 
| az vm host resize | Resize a dedicated host. | Core | GA | 
| az vm host restart | Restart the dedicated host. | Core | GA | 
| az vm host show | Get the details of a dedicated host. | Core | GA | 
| az vm host update | Update a dedicated host. | Core | GA | 
| az vm host wait | Place the CLI in a waiting state until a condition is met. | Core | GA | 
| az vm identity | Manage service identities of a VM. | Core | GA | 
| az vm identity assign | Enable managed service identity on a VM. | Core | GA | 
| az vm identity remove | Remove managed service identities from a VM. | Core | GA | 
| az vm identity show | Display VM's managed identity info. | Core | GA | 
| az vm image | Information on available virtual machine images. | Core | GA | 
| az vm image accept-terms | Accept Azure Marketplace term so that the image can be used to create VMs. | Core | Deprecated | 
| az vm image list | List the VM/VMSS images available in the Azure Marketplace. | Core | GA | 
| az vm image list-offers | List the VM image offers available in the Azure Marketplace. | Core | GA | 
| az vm image list-publishers | List the VM image publishers available in the Azure Marketplace. | Core | GA | 
| az vm image list-skus | List the VM image SKUs available in the Azure Marketplace. | Core | GA | 
| az vm image show | Get the details for a VM image available in the Azure Marketplace. | Core | GA | 
| az vm image terms | Manage Azure Marketplace image terms. | Core | GA | 
| az vm image terms accept | Accept Azure Marketplace image terms so that the image can be used to create VMs. | Core | GA | 
| az vm image terms cancel | Cancel Azure Marketplace image terms. | Core | GA | 
| az vm image terms show | Get the details of Azure Marketplace image terms. | Core | GA | 
| az vm install-patches | Install patches on a VM. | Core | GA | 
| az vm list | List details of Virtual Machines. | Core | GA | 
| az vm list-ip-addresses | List IP addresses associated with a VM. | Core | GA | 
| az vm list-sizes | List available sizes for VMs. | Core | Deprecated | 
| az vm list-skus | Get details for compute-related resource SKUs. | Core | GA | 
| az vm list-usage | List available usage resources for VMs. | Core | GA | 
| az vm list-vm-resize-options | List available resizing options for VMs. | Core | GA | 
| az vm migrate-to-vmss | Migrate a virtual machine from availability set to Flexible Virtual Machine Scale Set. | Core | GA | 
| az vm monitor | Manage monitor aspect for a vm. | Core | GA | 
| az vm monitor log | Manage log analytics workspace for a vm. | Core | GA | 
| az vm monitor log show | Execute a query against the Log Analytics workspace linked with a VM. | Core | GA | 
| az vm monitor metrics | Manage metrics for a vm. | Core | Preview | 
| az vm monitor metrics list-definitions | List the metric definitions for a VM. | Core | Preview | 
| az vm monitor metrics tail | List the metric values for a VM. | Core | Preview | 
| az vm nic | Manage network interfaces. See also  | Core | GA | 
| az vm nic add | Add existing NICs to a VM. | Core | GA | 
| az vm nic list | List the NICs available on a VM. | Core | GA | 
| az vm nic remove | Remove NICs from a VM. | Core | GA | 
| az vm nic set | Configure settings of a NIC attached to a VM. | Core | GA | 
| az vm nic show | Display information for a NIC attached to a VM. | Core | GA | 
| az vm open-port | Opens a VM to inbound traffic on specified ports. | Core | GA | 
| az vm perform-maintenance | The operation to perform maintenance on a virtual machine. | Core | GA | 
| az vm reapply | Reapply VMs. | Core | GA | 
| az vm redeploy | Redeploy an existing VM. | Core | GA | 
| az vm reimage | Reimage (upgrade the operating system) a virtual machine. | Core | GA | 
| az vm repair | Setup repair VMs with copied source OS Disk to resolve issues. | Extension | GA | 
| az vm repair create | Create a new repair VM and attach the source VM's copied OS disk as a data disk. | Extension | GA | 
| az vm repair list-scripts | List available scripts. Located https://github.com/Azure/repair-script-library. | Extension | GA | 
| az vm repair repair-and-restore | Repair and restore the VM. | Extension | Preview | 
| az vm repair repair-button | Repair button script. | Extension | Preview | 
| az vm repair reset-nic | Reset the network interface stack on the VM guest OS. https://free.blessedness.top/en-us/troubleshoot/azure/virtual-machines/reset-network-interface. | Extension | Preview | 
| az vm repair restore | Replace source VM's OS disk with data disk from repair VM. | Extension | GA | 
| az vm repair run | Run verified scripts from GitHub on a VM. 'az vm repair list-scripts' to view available scripts. | Extension | GA | 
| az vm resize | Update a VM's size. | Core | GA | 
| az vm restart | Restart VMs. | Core | GA | 
| az vm run-command | Manage run commands on a Virtual Machine. | Core | GA | 
| az vm run-command create | The operation to create the run command. | Core | GA | 
| az vm run-command delete | The operation to delete the run command. | Core | GA | 
| az vm run-command invoke | Execute a specific run command on a vm. | Core | GA | 
| az vm run-command list | List run commands from a VM or a location. | Core | GA | 
| az vm run-command show | Get specific run command. | Core | GA | 
| az vm run-command update | The operation to update the run command. | Core | GA | 
| az vm run-command wait | Place the CLI in a waiting state until a condition of the res virtual-machine-run-command is met. | Core | GA | 
| az vm secret | Manage VM secrets. | Core | GA | 
| az vm secret add | Add a secret to a VM. | Core | GA | 
| az vm secret format | Transform secrets into a form that can be used by VMs and VMSSes. | Core | GA | 
| az vm secret list | List secrets on a VM. | Core | GA | 
| az vm secret remove | Remove a secret from a VM. | Core | GA | 
| az vm show | Get the details of a VM. | Core | GA | 
| az vm simulate-eviction | Simulate the eviction of a Spot VM. | Core | GA | 
| az vm start | Start a stopped VM. | Core | GA | 
| az vm stop | Power off (stop) a running VM. | Core | GA | 
| az vm unmanaged-disk | Manage the unmanaged data disks attached to a VM. | Core | GA | 
| az vm unmanaged-disk attach | Attach an unmanaged persistent disk to a VM. | Core | GA | 
| az vm unmanaged-disk detach | Detach an unmanaged disk from a VM. | Core | GA | 
| az vm unmanaged-disk list | List unmanaged disks of a VM. | Core | GA | 
| az vm update | Update the properties of a VM. | Core | GA | 
| az vm user | Manage user accounts for a VM. | Core | GA | 
| az vm user delete | Delete a user account from a VM. | Core | GA | 
| az vm user reset-ssh | Reset the SSH configuration on a VM. | Core | GA | 
| az vm user update | Update a user account for VM. You can use it to update password or ssh key value for VM user. | Core | GA | 
| az vm wait | Place the CLI in a waiting state until a condition of the VM is met. | Core | GA | 
az vm assess-patches
Assess patches on a VM.
az vm assess-patches [--ids]
                     [--name --vm-name]
                     [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
                     [--resource-group]
                     [--subscription]Examples
Assess patches on a VM.
az vm assess-patches -g MyResourceGroup -n MyVmOptional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm auto-shutdown
Manage auto-shutdown for VM.
az vm auto-shutdown [--email]
                    [--ids]
                    [--location]
                    [--name]
                    [--off]
                    [--resource-group]
                    [--subscription]
                    [--time]
                    [--webhook]Examples
Create auto-shutdown schedule for a VM.
az vm auto-shutdown -g MyResourceGroup -n MyVm --time 1730 --email "foo@bar.com" --webhook "https://example.com/"Delete auto-shutdown schedule for a VM.
az vm auto-shutdown -g MyResourceGroup -n MyVm --offOptional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
The email recipient to send notifications to (can be a list of semi-colon separated email addresses).
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Location. Values from: az account list-locations. You can configure the default location using az configure --defaults location=<location>.
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Turn off auto-shutdown for VM. Configuration will be cleared.
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The UTC time of day the schedule will occur every day. Format: hhmm. Example: 1730.
The webhook URL to which the notification will be sent.
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm capture
Capture information for a stopped VM.
For an end-to-end tutorial, see https://free.blessedness.top/azure/virtual-machines/linux/capture-image.
az vm capture --vhd-name-prefix
              [--ids]
              [--name]
              [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
              [--overwrite {0, 1, f, false, n, no, t, true, y, yes}]
              [--resource-group]
              [--storage-container]
              [--subscription]Examples
Deallocate, generalize, and capture a stopped virtual machine.
az vm deallocate -g MyResourceGroup -n MyVm
az vm generalize -g MyResourceGroup -n MyVm
az vm capture -g MyResourceGroup -n MyVm --vhd-name-prefix MyPrefixDeallocate, generalize, and capture multiple stopped virtual machines.
az vm deallocate --ids MyVmIds
az vm generalize --ids MyVmIds
az vm capture --ids MyVmIds --vhd-name-prefix MyPrefixRequired Parameters
The VHD name prefix specify for the VM disks.
| Property | Value | 
|---|---|
| Parameter group: | Parameters Arguments | 
Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the virtual machine.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Overwrite the existing disk file.
| Property | Value | 
|---|---|
| Parameter group: | Parameters Arguments | 
| Default value: | True | 
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The storage account container name in which to save the disks.
| Property | Value | 
|---|---|
| Parameter group: | Parameters Arguments | 
| Default value: | vhds | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm convert
Convert a VM with unmanaged disks to use managed disks.
az vm convert [--ids]
              [--name --vm-name]
              [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
              [--resource-group]
              [--subscription]Examples
Convert a VM with unmanaged disks to use managed disks.
az vm convert -g MyResourceGroup -n MyVmConvert all VMs with unmanaged disks in a resource group to use managed disks.
az vm convert --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm create
Create an Azure Virtual Machine.
For an end-to-end tutorial, see https://free.blessedness.top/azure/virtual-machines/linux/quick-create-cli.
az vm create --name
             --resource-group
             [--accelerated-networking {false, true}]
             [--accept-term]
             [--additional-events --additional-scheduled-events {false, true}]
             [--admin-password]
             [--admin-username]
             [--align-regional-disks --align-regional-disks-to-vm-zone {false, true}]
             [--asgs]
             [--assign-identity]
             [--attach-data-disks]
             [--attach-os-disk]
             [--authentication-type {all, password, ssh}]
             [--availability-set]
             [--boot-diagnostics-storage]
             [--capacity-reservation-group --crg]
             [--computer-name]
             [--count]
             [--custom-data]
             [--data-disk-caching]
             [--data-disk-delete-option]
             [--data-disk-encryption-sets]
             [--data-disk-sizes-gb]
             [--disable-integrity-monitoring-autoupgrade]
             [--disk-controller-type {NVMe, SCSI}]
             [--edge-zone]
             [--enable-agent {false, true}]
             [--enable-auto-update {false, true}]
             [--enable-hibernation {false, true}]
             [--enable-hotpatching {false, true}]
             [--enable-integrity-monitoring]
             [--enable-proxy-agent {false, true}]
             [--enable-reboot --enable-user-reboot-scheduled-events {false, true}]
             [--enable-redeploy --enable-user-redeploy-scheduled-events {false, true}]
             [--enable-secure-boot {false, true}]
             [--enable-vtpm {false, true}]
             [--encryption-at-host {false, true}]
             [--encryption-identity]
             [--ephemeral-os-disk {false, true}]
             [--ephemeral-os-disk-placement --ephemeral-placement {CacheDisk, NvmeDisk, ResourceDisk}]
             [--eviction-policy {Deallocate, Delete}]
             [--exclude-zones]
             [--generate-ssh-keys]
             [--host]
             [--host-group]
             [--image]
             [--imds-access-control-profile-reference-id --imds-profile-id]
             [--imds-mode {Audit, Enforce}]
             [--include-zones]
             [--key-incarnation-id]
             [--license-type {None, RHEL_BASE, RHEL_BASESAPAPPS, RHEL_BASESAPHA, RHEL_BYOS, RHEL_ELS_6, RHEL_EUS, RHEL_SAPAPPS, RHEL_SAPHA, SLES, SLES_BYOS, SLES_HPC, SLES_SAP, SLES_STANDARD, UBUNTU, UBUNTU_PRO, Windows_Client, Windows_Server}]
             [--location]
             [--max-price]
             [--nic-delete-option]
             [--nics]
             [--no-wait]
             [--nsg]
             [--nsg-rule {NONE, RDP, SSH}]
             [--os-disk-caching {None, ReadOnly, ReadWrite}]
             [--os-disk-delete-option {Delete, Detach}]
             [--os-disk-encryption-set]
             [--os-disk-name]
             [--os-disk-secure-vm-disk-encryption-set]
             [--os-disk-security-encryption-type {DiskWithVMGuestState, NonPersistedTPM, VMGuestStateOnly}]
             [--os-disk-size-gb]
             [--os-type {linux, windows}]
             [--patch-mode {AutomaticByOS, AutomaticByPlatform, ImageDefault, Manual}]
             [--plan-name]
             [--plan-product]
             [--plan-promotion-code]
             [--plan-publisher]
             [--platform-fault-domain]
             [--ppg]
             [--priority {Low, Regular, Spot}]
             [--private-ip-address]
             [--proxy-agent-mode {Audit, Enforce}]
             [--public-ip-address]
             [--public-ip-address-allocation {dynamic, static}]
             [--public-ip-address-dns-name]
             [--public-ip-sku {Basic, Standard}]
             [--role]
             [--scope]
             [--secrets]
             [--security-type {ConfidentialVM, Standard, TrustedLaunch}]
             [--size]
             [--source-disk-restore-point --source-disk-rp]
             [--source-disk-restore-point-size-gb --source-rp-size]
             [--source-resource --source-snapshots-or-disks]
             [--source-resource-size --source-snapshots-or-disks-size-gb]
             [--specialized {false, true}]
             [--ssh-dest-key-path]
             [--ssh-key-name]
             [--ssh-key-type {Ed25519, RSA}]
             [--ssh-key-values]
             [--storage-account]
             [--storage-container-name]
             [--storage-sku]
             [--subnet]
             [--subnet-address-prefix]
             [--tags]
             [--ultra-ssd-enabled {false, true}]
             [--use-unmanaged-disk]
             [--user-data]
             [--v-cpus-available]
             [--v-cpus-per-core]
             [--validate]
             [--vmss]
             [--vnet-address-prefix]
             [--vnet-name]
             [--wire-server-access-control-profile-reference-id --wire-server-profile-id]
             [--wire-server-mode {Audit, Enforce}]
             [--workspace]
             [--zone]
             [--zone-placement-policy {Any}]Examples
Create a default Ubuntu2204 VM with automatic SSH authentication.
az vm create -n MyVm -g MyResourceGroup --image Ubuntu2204Create a default RedHat VM with automatic SSH authentication using an image URN.
az vm create -n MyVm -g MyResourceGroup --image RedHat:RHEL:7-RAW:7.4.2018010506Create a default Windows Server VM with a private IP address.
az vm create -n MyVm -g MyResourceGroup --public-ip-address "" --image Win2012R2DatacenterCreate a VM from a custom managed image.
az vm create -g MyResourceGroup -n MyVm --image MyImageCreate a VM from a generalized gallery image version.
az vm create -g MyResourceGroup -n MyVm --image /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myRG/providers/Microsoft.Compute/galleries/myGallery/images/myImage/versions/1.0.0Create a VM from a specialized gallery image version.
az vm create -g MyResourceGroup -n MyVm --image /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myRG/providers/Microsoft.Compute/galleries/myGallery/images/myImage/versions/1.0.0 --specializedCreate a VM from the latest version of a gallery image
az vm create -g MyResourceGroup -n MyVm --image /subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/myRG/providers/Microsoft.Compute/galleries/myGallery/images/myImageCreate a VM by attaching to a managed operating system disk.
az vm create -g MyResourceGroup -n MyVm --attach-os-disk MyOsDisk --os-type linuxCreate a VM by attaching to an unmanaged operating system disk from a VHD blob uri.
az vm create -g MyResourceGroup -n MyVm --attach-os-disk https://vhd1234.blob.core.windows.net/vhds/osdisk1234.vhd --os-type linux --use-unmanaged-diskCreate an Debian11 VM using a cloud-init script for configuration. See: https://free.blessedness.top/azure/virtual-machines/linux/using-cloud-init.
az vm create -g MyResourceGroup -n MyVm --image Debian11 --custom-data MyCloudInitScript.ymlCreate a Debian11 VM with SSH key authentication and a public DNS entry, located on an existing virtual network and availability set.
az vm create -n MyVm -g MyResourceGroup --image Debian11 --vnet-name MyVnet --subnet subnet1 \
    --availability-set MyAvailabilitySet --public-ip-address-dns-name MyUniqueDnsName \
    --ssh-key-values @key-fileCreate a simple Ubuntu Linux VM with a public IP address, DNS entry, two data disks (10GB and 20GB), and then generate RSA ssh key pairs.
az vm create -n MyVm -g MyResourceGroup --public-ip-address-dns-name MyUniqueDnsName \
    --image Ubuntu2204 --data-disk-sizes-gb 10 20 --size Standard_DS2_v2 \
    --generate-ssh-keysCreate a Debian11 VM using Key Vault secrets.
az keyvault certificate create --vault-name vaultname -n cert1 \
  -p "$(az keyvault certificate get-default-policy)"
secrets=$(az keyvault secret list-versions --vault-name vaultname \
  -n cert1 --query "[?attributes.enabled].id" -o tsv)
vm_secrets=$(az vm secret format -s "$secrets")
az vm create -g group-name -n vm-name --admin-username deploy  \
  --image debian11 --secrets "$vm_secrets"Create a CentOS VM with a system assigned identity. The VM will have a 'Contributor' role with access to a storage account.
az vm create -n MyVm -g rg1 --image CentOS85Gen2 --assign-identity [system] --scope /subscriptions/99999999-1bf0-4dda-aec3-cb9272f09590/MyResourceGroup/myRG/providers/Microsoft.Storage/storageAccounts/storage1 --role ContributorCreate a Debian11 VM with a user assigned identity.
az vm create -n MyVm -g rg1 --image Debian11 --assign-identity /subscriptions/99999999-1bf0-4dda-aec3-cb9272f09590/resourcegroups/myRG/providers/Microsoft.ManagedIdentity/userAssignedIdentities/myIDCreate a Debian11 VM with both system and user assigned identity.
az vm create -n MyVm -g rg1 --image Debian11 --assign-identity [system] /subscriptions/99999999-1bf0-4dda-aec3-cb9272f09590/resourcegroups/myRG/providers/Microsoft.ManagedIdentity/userAssignedIdentities/myIDCreate a vm with user assigned identity and add encryption identity for Azure disk encryption
az vm create -n MyVm -g rg1 --image Debian11 --assign-identity myID --encryption-identity /subscriptions/00000000-0000-0000-0000-000000000000/resourcegroups/myRG/providers/Microsoft.ManagedIdentity/userAssignedIdentities/myIDCreate a VM in an availability zone in the current resource group's region.
az vm create -n MyVm -g MyResourceGroup --image CentOS85Gen2 --zone 1Create multiple VMs. In this example, 3 VMs are created. They are MyVm0, MyVm1, MyVm2.
az vm create -n MyVm -g MyResourceGroup --image CentOS85Gen2 --count 3Create a VM from shared gallery image
az vm create -n MyVm -g MyResourceGroup --image /SharedGalleries/{gallery_unique_name}/Images/{image}/Versions/{version}Create a VM from community gallery image
az vm create -n MyVm -g MyResourceGroup --image /CommunityGalleries/{gallery_unique_name}/Images/{image}/Versions/{version}Required Parameters
Name of the virtual machine.
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Enable accelerated networking. Unless specified, CLI will enable it based on machine image and size.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
| Accepted values: | false, true | 
Accept the license agreement and privacy statement.
The configuration parameter used while creating event grid and resource graph scheduled event setting.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Password for the VM if authentication type is 'Password'.
| Property | Value | 
|---|---|
| Parameter group: | Authentication Arguments | 
Username for the VM. Default value is current username of OS. If the default value is system reserved, then default value will be set to azureuser. Please refer to https://free.blessedness.top/rest/api/compute/virtualmachines/createorupdate#osprofile to get a full list of reserved values.
| Property | Value | 
|---|---|
| Parameter group: | Authentication Arguments | 
Specify whether the regional disks should be aligned/moved to the VM zone. This is applicable only for VMs with placement property set. Please note that this change is irreversible.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Space-separated list of existing application security groups to associate with the VM.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
Accept system or user assigned identities separated by spaces. Use '[system]' to refer system assigned identity, or a resource id to refer user assigned identity. Check out help for more examples.
| Property | Value | 
|---|---|
| Parameter group: | Managed Service Identity Arguments | 
Attach existing data disks to the VM. Can use the name or ID of a managed disk or the URI to an unmanaged disk VHD.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Attach an existing OS disk to the VM. Can use the name or ID of a managed disk or the URI to an unmanaged disk VHD.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Type of authentication to use with the VM. Defaults to password for Windows and SSH public key for Linux. "all" enables both ssh and password authentication.
| Property | Value | 
|---|---|
| Parameter group: | Authentication Arguments | 
| Accepted values: | all, password, ssh | 
Name or ID of an existing availability set to add the VM to. None by default.
Pre-existing storage account name or its blob uri to capture boot diagnostics. Its sku should be one of Standard_GRS, Standard_LRS and Standard_RAGRS.
The ID or name of the capacity reservation group that is used to allocate. Pass in "None" to disassociate the capacity reservation group. Please note that if you want to delete a VM/VMSS that has been associated with capacity reservation group, you need to disassociate the capacity reservation group first.
The host OS name of the virtual machine. Defaults to the name of the VM.
Number of virtual machines to create. Value range is [2, 250], inclusive. Don't specify this parameter if you want to create a normal single VM. The VMs are created in parallel. The output of this command is an array of VMs instead of one single VM. Each VM has its own public IP, NIC. VNET and NSG are shared. It is recommended that no existing public IP, NIC, VNET and NSG are in resource group. When --count is specified, --attach-data-disks, --attach-os-disk, --boot-diagnostics-storage, --computer-name, --host, --host-group, --nics, --os-disk-name, --private-ip-address, --public-ip-address, --public-ip-address-dns-name, --storage-account, --storage-container-name, --subnet, --use-unmanaged-disk, --vnet-name are not allowed.
Custom init script file or text (cloud-init, cloud-config, etc..).
Storage caching type for data disk(s), including 'None', 'ReadOnly', 'ReadWrite', etc. Use a singular value to apply on all disks, or use <lun>=<vaule1> <lun>=<value2> to configure individual disk.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Specify whether data disk should be deleted or detached upon VM deletion. If a single data disk is attached, the allowed values are Delete and Detach. For multiple data disks are attached, please use <data_disk>=Delete <data_disk2>=Detach to configure each disk.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Names or IDs (space delimited) of disk encryption sets for data disks.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Space-separated empty managed data disk sizes in GB to create.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Disable auto upgrade of guest attestation extension for Trusted Launch enabled VMs and VMSS.
| Property | Value | 
|---|---|
| Default value: | False | 
Specify the disk controller type configured for the VM or VMSS.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Accepted values: | NVMe, SCSI | 
The name of edge zone.
Indicates whether virtual machine agent should be provisioned on the virtual machine. When this property is not specified, default behavior is to set it to true. This will ensure that VM Agent is installed on the VM so that extensions can be added to the VM later.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Indicate whether Automatic Updates is enabled for the Windows virtual machine.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
The flag that enable or disable hibernation capability on the VM.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Patch VMs without requiring a reboot. --enable-agent must be set and --patch-mode must be set to AutomaticByPlatform.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Enable installing Microsoft propietary and not security supported guest attestation extension and enabling System Assigned Identity for Trusted Launch enabled VMs and VMSS.
| Property | Value | 
|---|---|
| Default value: | False | 
Specify whether metadata security protoco (proxy agent) feature should be enabled on the virtual machine or virtual machine scale set.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
The configuration parameter used while publishing scheduled events additional publishing targets.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
The configuration parameter used while creating user initiated redeploy scheduled event setting creation.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Enable secure boot.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Enable vTPM.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Enable Host Encryption for the VM or VMSS. This will enable the encryption for all the disks including Resource/Temp disk at host itself.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Accepted values: | false, true | 
Resource Id of the user managed identity which can be used for Azure disk encryption.
Allows you to create an OS disk directly on the host node, providing local disk performance and faster VM/VMSS reimage time.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Accepted values: | false, true | 
Only applicable when used with --ephemeral-os-disk. Allows you to choose the Ephemeral OS disk provisioning location.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Accepted values: | CacheDisk, NvmeDisk, ResourceDisk | 
The eviction policy for the Spot priority virtual machine. Default eviction policy is Deallocate for a Spot priority virtual machine.
| Property | Value | 
|---|---|
| Accepted values: | Deallocate, Delete | 
If "--zone-placement-policy" is set to "Any", availability zone selected by the system must not be present in the list of availability zones passed with "excludeZones". If "--exclude-zones" is not provided, all availability zones in region will be considered for selection.
Generate SSH public and private key files if missing. The keys will be stored in the ~/.ssh directory.
| Property | Value | 
|---|---|
| Parameter group: | Authentication Arguments | 
| Default value: | False | 
Resource ID of the dedicated host that the VM will reside in. --host and --host-group can't be used together.
| Property | Value | 
|---|---|
| Parameter group: | Dedicated Host Arguments | 
Name or resource ID of the dedicated host group that the VM will reside in. --host and --host-group can't be used together.
| Property | Value | 
|---|---|
| Parameter group: | Dedicated Host Arguments | 
The name of the operating system image as a URN alias, URN, custom image name or ID, custom image version ID, or VHD blob URI. In addition, it also supports shared gallery image. Please use the image alias including the version of the distribution you want to use. For example: please use Debian11 instead of Debian.' This parameter is required unless using --attach-os-disk. Valid URN format: "Publisher:Offer:Sku:Version". For more information, see https://free.blessedness.top/azure/virtual-machines/linux/cli-ps-findimage.
| Property | Value | 
|---|---|
| Value from: | az sig image-version show-shared, az vm image list, az vm image show | 
Specify the access control profile version resource id resource id of imds.
Specify the mode that proxy agent will execute on if the feature is enabled.
| Property | Value | 
|---|---|
| Accepted values: | Audit, Enforce | 
If "--zone-placement-policy" is set to "Any", availability zone selected by the system must be present in the list of availability zones passed with "--include-zones". If "--include-zones" is not provided, all availability zones in region will be considered for selection.
Increase the value of this property allows user to reset the key used for securing communication channel between guest and host.
Specifies that the Windows image or disk was licensed on-premises. To enable Azure Hybrid Benefit for Windows Server, use 'Windows_Server'. To enable Multi-tenant Hosting Rights for Windows 10, use 'Windows_Client'. For more information see the Azure Windows VM online docs.
| Property | Value | 
|---|---|
| Accepted values: | None, RHEL_BASE, RHEL_BASESAPAPPS, RHEL_BASESAPHA, RHEL_BYOS, RHEL_ELS_6, RHEL_EUS, RHEL_SAPAPPS, RHEL_SAPHA, SLES, SLES_BYOS, SLES_HPC, SLES_SAP, SLES_STANDARD, UBUNTU, UBUNTU_PRO, Windows_Client, Windows_Server | 
Location in which to create VM and related resources. If default location is not configured, will default to the resource group's location.
The maximum price (in US Dollars) you are willing to pay for a Spot VM/VMSS. -1 indicates that the Spot VM/VMSS should not be evicted for price reasons.
Specify what happens to the network interface when the VM is deleted. Use a singular value to apply on all resources, or use <Name>=<Value> to configure the delete behavior for individual resources. Possible options are Delete and Detach.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
Names or IDs of existing NICs to attach to the VM. The first NIC will be designated as primary. If omitted, a new NIC will be created. If an existing NIC is specified, do not specify subnet, VNet, public IP or NSG.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Default value: | False | 
The name to use when creating a new Network Security Group (default) or referencing an existing one. Can also reference an existing NSG by ID or specify "" for none ('""' in Azure CLI using PowerShell or --% operator).
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
NSG rule to create when creating a new NSG. Defaults to open ports for allowing RDP on Windows and allowing SSH on Linux. NONE represents no NSG rule.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
| Accepted values: | NONE, RDP, SSH | 
Storage caching type for the VM OS disk. Default: ReadWrite.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Accepted values: | None, ReadOnly, ReadWrite | 
Specify the behavior of the managed disk when the VM gets deleted i.e whether the managed disk is deleted or detached.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Accepted values: | Delete, Detach | 
Name or ID of disk encryption set for OS disk.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
The name of the new VM OS disk.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Specify the customer managed disk encryption set resource ID or name for the managed disk that is used for customer managed key encrypted Confidential VM OS disk and VM guest blob.
Specify the encryption type of the OS managed disk.
| Property | Value | 
|---|---|
| Accepted values: | DiskWithVMGuestState, NonPersistedTPM, VMGuestStateOnly | 
OS disk size in GB to create.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Type of OS installed on a custom VHD. Do not use when specifying an URN or URN alias.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Accepted values: | linux, windows | 
Mode of in-guest patching to IaaS virtual machine. Allowed values for Windows VM: AutomaticByOS, AutomaticByPlatform, Manual. Allowed values for Linux VM: AutomaticByPlatform, ImageDefault. Manual - You control the application of patches to a virtual machine. You do this by applying patches manually inside the VM. In this mode, automatic updates are disabled; the paramater --enable-auto-update must be false. AutomaticByOS - The virtual machine will automatically be updated by the OS. The parameter --enable-auto-update must be true. AutomaticByPlatform - the virtual machine will automatically updated by the OS. ImageDefault - The virtual machine's default patching configuration is used. The parameter --enable-agent and --enable-auto-update must be true.
| Property | Value | 
|---|---|
| Accepted values: | AutomaticByOS, AutomaticByPlatform, ImageDefault, Manual | 
Plan name.
| Property | Value | 
|---|---|
| Parameter group: | Marketplace Image Plan Arguments | 
Plan product.
| Property | Value | 
|---|---|
| Parameter group: | Marketplace Image Plan Arguments | 
Plan promotion code.
| Property | Value | 
|---|---|
| Parameter group: | Marketplace Image Plan Arguments | 
Plan publisher.
| Property | Value | 
|---|---|
| Parameter group: | Marketplace Image Plan Arguments | 
Specify the scale set logical fault domain into which the virtual machine will be created. By default, the virtual machine will be automatically assigned to a fault domain that best maintains balance across available fault domains. This is applicable only if the virtualMachineScaleSet property of this virtual machine is set. The virtual machine scale set that is referenced, must have platform fault domain count. This property cannot be updated once the virtual machine is created. Fault domain assignment can be viewed in the virtual machine instance view.
The name or ID of the proximity placement group the VM should be associated with.
Priority. Use 'Spot' to run short-lived workloads in a cost-effective way. 'Low' enum will be deprecated in the future. Please use 'Spot' to deploy Azure spot VM and/or VMSS. Default to Regular.
| Property | Value | 
|---|---|
| Accepted values: | Low, Regular, Spot | 
Static private IP address (e.g. 10.0.0.5).
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
Option '--proxy-agent-mode' has been deprecated and will be removed in a future release. Use '--wire-server-mode' instead.
Specify the mode that proxy agent will execute on if the feature is enabled.
| Property | Value | 
|---|---|
| Accepted values: | Audit, Enforce | 
Name of the public IP address when creating one (default) or referencing an existing one. Can also reference an existing public IP by ID or specify "" or '' for None ('""' in Azure CLI using PowerShell).
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
| Accepted values: | dynamic, static | 
Globally unique DNS name for a newly created public IP.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
Public IP SKU. The public IP is supported to be created on edge zone only when it is 'Standard'.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
| Default value: | Standard | 
| Accepted values: | Basic, Standard | 
Role name or id the system assigned identity will have.
| Property | Value | 
|---|---|
| Parameter group: | Managed Service Identity Arguments | 
Scope that the system assigned identity can access.
| Property | Value | 
|---|---|
| Parameter group: | Managed Service Identity Arguments | 
One or many Key Vault secrets as JSON strings or files via @{path} containing [{ "sourceVault": { "id": "value" }, "vaultCertificates": [{ "certificateUrl": "value", "certificateStore": "cert store name (only on windows)"}] }].
Specify the security type of the virtual machine. The value Standard can be used if subscription has feature flag UseStandardSecurityType registered under Microsoft.Compute namespace. Refer to https://free.blessedness.top/en-us/azure/azure-resource-manager/management/preview-features for steps to enable required feature.
| Property | Value | 
|---|---|
| Accepted values: | ConfidentialVM, Standard, TrustedLaunch | 
The VM size to be created. See https://azure.microsoft.com/pricing/details/virtual-machines/ for size info.
| Property | Value | 
|---|---|
| Default value: | Standard_DS1_v2 | 
| Value from: | az vm list-sizes | 
Create a data disk from a disk restore point. Can use the ID of a disk restore point.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
The size of the source disk restore point in GB.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Create a data disk from a snapshot or another disk. Can use the ID of a disk or snapshot.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
The size of the source disk in GB.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Indicate whether the source image is specialized.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Accepted values: | false, true | 
Destination file path on the VM for the SSH key. If the file already exists, the specified key(s) are appended to the file. Destination path for SSH public keys is currently limited to its default value "/home/username/.ssh/authorized_keys" due to a known issue in Linux provisioning agent.
| Property | Value | 
|---|---|
| Parameter group: | Authentication Arguments | 
Use it as public key in virtual machine. It should be an existing SSH key resource in Azure.
Specify the type of SSH public and private key files to be generated if missing.
| Property | Value | 
|---|---|
| Parameter group: | Authentication Arguments | 
| Default value: | RSA | 
| Accepted values: | Ed25519, RSA | 
Space-separated list of SSH public keys or public key file paths.
| Property | Value | 
|---|---|
| Parameter group: | Authentication Arguments | 
Only applicable when used with --use-unmanaged-disk. The name to use when creating a new storage account or referencing an existing one. If omitted, an appropriate storage account in the same resource group and location will be used, or a new one will be created.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
Only applicable when used with --use-unmanaged-disk. Name of the storage container for the VM OS disk. Default: vhds.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
The SKU of the storage account with which to persist VM. Use a singular sku that would be applied across all disks, or specify individual disks. Usage: [--storage-sku SKU | --storage-sku ID=SKU ID=SKU ID=SKU...], where each ID is "os" or a 0-indexed lun. Allowed values: Standard_LRS, Premium_LRS, StandardSSD_LRS, UltraSSD_LRS, Premium_ZRS, StandardSSD_ZRS, PremiumV2_LRS.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
The name of the subnet when creating a new VNet or referencing an existing one. Can also reference an existing subnet by ID. If both vnet-name and subnet are omitted, an appropriate VNet and subnet will be selected automatically, or a new one will be created.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
The subnet IP address prefix to use when creating a new VNet in CIDR format.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
| Default value: | 10.0.0.0/24 | 
Space-separated tags: key[=value] [key[=value] ...]. Use "" to clear existing tags.
Enables or disables the capability to have 1 or more managed data disks with UltraSSD_LRS storage account.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Accepted values: | false, true | 
Do not use managed disk to persist VM.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Default value: | False | 
UserData for the VM. It can be passed in as file or string.
Specify the number of vCPUs available.
Specify the ratio of vCPU to physical core. Setting this property to 1 also means that hyper-threading is disabled.
Generate and validate the ARM template without creating any resources.
| Property | Value | 
|---|---|
| Default value: | False | 
Name or ID of an existing virtual machine scale set that the virtual machine should be assigned to. None by default.
The IP address prefix to use when creating a new VNet in CIDR format.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
| Default value: | 10.0.0.0/16 | 
Name of the virtual network when creating a new one or referencing an existing one.
| Property | Value | 
|---|---|
| Parameter group: | Network Arguments | 
Specify the access control profile version resource id of wire server.
Specify the mode that proxy agent will execute on if the feature is enabled.
| Property | Value | 
|---|---|
| Accepted values: | Audit, Enforce | 
Name or ID of Log Analytics Workspace. If you specify the workspace through its name, the workspace should be in the same resource group with the vm, otherwise a new workspace will be created.
| Property | Value | 
|---|---|
| Parameter group: | Monitor Arguments | 
Availability zone into which to provision the resource.
Specify the policy for virtual machine's placement in availability zone.
| Property | Value | 
|---|---|
| Accepted values: | Any | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm deallocate
Deallocate a VM so that computing resources are no longer allocated (charges no longer apply). The status will change from 'Stopped' to 'Stopped (Deallocated)'.
For an end-to-end tutorial, see https://free.blessedness.top/azure/virtual-machines/linux/capture-image.
az vm deallocate [--hibernate {0, 1, f, false, n, no, t, true, y, yes}]
                 [--ids]
                 [--name --vm-name]
                 [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
                 [--resource-group]
                 [--subscription]Examples
Deallocate, generalize, and capture a stopped virtual machine.
az vm deallocate -g MyResourceGroup -n MyVm
az vm generalize -g MyResourceGroup -n MyVm
az vm capture -g MyResourceGroup -n MyVm --vhd-name-prefix MyPrefixDeallocate, generalize, and capture multiple stopped virtual machines.
az vm deallocate --ids vms_ids
az vm generalize --ids vms_ids
az vm capture --ids vms_ids --vhd-name-prefix MyPrefixDeallocate a VM.
az vm deallocate --name MyVm --no-wait --resource-group MyResourceGroupOptional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Optional parameter to hibernate a virtual machine. (Feature in Preview).
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm delete
Delete operation to delete a virtual machine.
az vm delete [--force-deletion {0, 1, f, false, n, no, t, true, y, yes}]
             [--ids]
             [--name]
             [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
             [--resource-group]
             [--subscription]
             [--yes]Examples
Delete a VM without a prompt for confirmation.
az vm delete -g MyResourceGroup -n MyVm --yesDelete all VMs in a resource group.
az vm delete --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Optional parameter to force delete virtual machines.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the virtual machine.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not prompt for confirmation.
| Property | Value | 
|---|---|
| Default value: | False | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm generalize
Mark a VM as generalized, allowing it to be imaged for multiple deployments.
For an end-to-end tutorial, see https://free.blessedness.top/azure/virtual-machines/linux/capture-image.
az vm generalize [--ids]
                 [--name --vm-name]
                 [--resource-group]
                 [--subscription]Examples
Deallocate, generalize, and capture a stopped virtual machine.
az vm deallocate -g MyResourceGroup -n MyVm
az vm generalize -g MyResourceGroup -n MyVm
az vm capture -g MyResourceGroup -n MyVm --vhd-name-prefix MyPrefixDeallocate, generalize, and capture multiple stopped virtual machines.
az vm deallocate --ids vms_ids
az vm generalize --ids vms_ids
az vm capture --ids vms_ids --vhd-name-prefix MyPrefixOptional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm get-instance-view
Get instance information about a VM.
az vm get-instance-view [--ids]
                        [--name]
                        [--resource-group]
                        [--subscription]Examples
Use a resource group and name to get instance view information of a VM.
az vm get-instance-view -g MyResourceGroup -n MyVmGet instance views for all VMs in a resource group.
az vm get-instance-view --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm install-patches
Install patches on a VM.
az vm install-patches --maximum-duration
                      --reboot-setting {Always, IfRequired, Never}
                      [--classifications-to-include-linux {Critical, Other, Security}]
                      [--classifications-to-include-win {Critical, Definition, FeaturePack, Security, ServicePack, Tools, UpdateRollUp, Updates}]
                      [--exclude-kbs-requiring-reboot {false, true}]
                      [--ids]
                      [--kb-numbers-to-exclude]
                      [--kb-numbers-to-include]
                      [--max-patch-publish-date]
                      [--name]
                      [--no-wait]
                      [--package-name-masks-to-exclude]
                      [--package-name-masks-to-include]
                      [--resource-group]
                      [--subscription]Examples
Install patches on a windows VM, allowing the maximum amount of time to be 4 hours, and the VM will reboot if required during the software update operation.
az vm install-patches -g MyResourceGroup -n MyVm --maximum-duration PT4H --reboot-setting IfRequired --classifications-to-include-win Critical Security --exclude-kbs-requiring-reboot trueInstall patches on a linux VM, allowing the maximum amount of time to be 4 hours, and the VM will reboot if required during the software update operation.
az vm install-patches -g MyResourceGroup -n MyVm --maximum-duration PT4H --reboot-setting IfRequired --classifications-to-include-linux CriticalRequired Parameters
Specify the maximum amount of time that the operation will run. It must be an ISO 8601-compliant duration string such as PT4H (4 hours).
Define when it is acceptable to reboot a VM during a software update operation.
| Property | Value | 
|---|---|
| Accepted values: | Always, IfRequired, Never | 
Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Space-separated list of classifications to include for Linux VM.
| Property | Value | 
|---|---|
| Accepted values: | Critical, Other, Security | 
Space-separated list of classifications to include for Windows VM.
| Property | Value | 
|---|---|
| Accepted values: | Critical, Definition, FeaturePack, Security, ServicePack, Tools, UpdateRollUp, Updates | 
Filter out KBs that don't have a reboot behavior of 'NeverReboots' when this is set. Applicable to Windows VM only.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Space-separated list of KBs to exclude in the patch operation. Applicable to Windows VM only.
Space-separated list of KBs to include in the patch operation. Applicable to Windows VM only.
ISO 8601 time value for install patch that were published on or before this given max published date. Format: date (yyyy-mm-dd) time (hh:mm:ss.xxxxx) timezone (+/-hh:mm).
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Default value: | False | 
Space-separated list of packages to exclude in the patch operation. Format: packageName_packageVersion. Applicable to Linux VM only.
Space-separated list of packages to include in the patch operation. Format: packageName_packageVersion. Applicable to Linux VM only.
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm list
List details of Virtual Machines.
--resource-group can pass in an empty string as a parameter, which will output all VM information under the subscription. For more information on querying information about Virtual Machines, see https://free.blessedness.top/cli/azure/query-az-cli2.
az vm list [--resource-group]
           [--show-details]
           [--vmss]Examples
List all VMs.
az vm listList all VMs by resource group.
az vm list -g MyResourceGroupList all VMs by resource group with details.
az vm list -g MyResourceGroup -dOptional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
Show public ip address, FQDN, and power states. command will run slow.
| Property | Value | 
|---|---|
| Default value: | False | 
List VM instances in a specific VMSS. Please specify the VMSS id or VMSS name.
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm list-ip-addresses
List IP addresses associated with a VM.
az vm list-ip-addresses [--ids]
                        [--name]
                        [--resource-group]
                        [--subscription]Examples
Get the IP addresses for a VM.
az vm list-ip-addresses -g MyResourceGroup -n MyVmGet IP addresses for all VMs in a resource group.
az vm list-ip-addresses --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm list-sizes
This command has been deprecated and will be removed in a future release. Use 'az vm list-skus' instead.
List available sizes for VMs.
az vm list-sizes --locationExamples
List the available VM sizes in the West US region.
az vm list-sizes -l westusRequired Parameters
Location. Values from: az account list-locations. You can configure the default location using az configure --defaults location=<location>.
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm list-skus
Get details for compute-related resource SKUs.
This command incorporates subscription level restriction, offering the most accurate information.
az vm list-skus [--all {false, true}]
                [--location]
                [--resource-type]
                [--size]
                [--zone {false, true}]Examples
List all SKUs in the West US region.
az vm list-skus -l westusList all available vm sizes in the East US2 region which support availability zone.
az vm list-skus -l eastus2 --zoneList all available vm sizes in the East US2 region which support availability zone with name like "standard_ds1...".
az vm list-skus -l eastus2 --zone --size standard_ds1List availability set related sku information in The West US region.
az vm list-skus -l westus --resource-type availabilitySetsOptional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Show all information including vm sizes not available under the current subscription.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Location. Values from: az account list-locations. You can configure the default location using az configure --defaults location=<location>.
Resource types e.g. "availabilitySets", "snapshots", "disks", etc.
Size name, partial name is accepted.
Show skus supporting availability zones.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm list-usage
List available usage resources for VMs.
az vm list-usage --locationExamples
Get the compute resource usage for the West US region.
az vm list-usage -l westusRequired Parameters
Location. Values from: az account list-locations. You can configure the default location using az configure --defaults location=<location>.
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm list-vm-resize-options
List available resizing options for VMs.
az vm list-vm-resize-options [--ids]
                             [--name --vm-name]
                             [--resource-group]
                             [--subscription]Examples
List all available VM sizes for resizing.
az vm list-vm-resize-options -g MyResourceGroup -n MyVmList available sizes for all VMs in a resource group.
az vm list-vm-resize-options --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm migrate-to-vmss
Migrate a virtual machine from availability set to Flexible Virtual Machine Scale Set.
az vm migrate-to-vmss [--ids]
                      [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
                      [--resource-group]
                      [--subscription]
                      [--target-fault-domain]
                      [--target-vm-size]
                      [--target-zone]
                      [--vm-name]Examples
Migrate a vm to flexible vmss
az vm migrate-to-vmss --resource-group myResourceGroup --vm-name myVMName --target-fault-domain 0 --target-vm-size Standard_D1_v2Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The target compute fault domain of VM migration to Flexible Virtual Machine Scale Set.
| Property | Value | 
|---|---|
| Parameter group: | Parameters Arguments | 
The target Virtual Machine size of VM migration to Flexible Virtual Machine Scale Set.
| Property | Value | 
|---|---|
| Parameter group: | Parameters Arguments | 
The target zone of VM migration to Flexible Virtual Machine Scale Set.
| Property | Value | 
|---|---|
| Parameter group: | Parameters Arguments | 
The name of the virtual machine.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm open-port
Opens a VM to inbound traffic on specified ports.
Adds a security rule to the network security group (NSG) that is attached to the VM's network interface (NIC) or subnet. The existing NSG will be used or a new one will be created. The rule name is 'open-port-{port}' and will overwrite an existing rule with this name. For multi-NIC VMs, or for more fine-grained control, use the appropriate network commands directly (nsg rule create, etc).
az vm open-port --port
                [--apply-to-subnet]
                [--ids]
                [--name]
                [--nsg-name]
                [--priority]
                [--resource-group]
                [--subscription]Examples
Open all ports on a VM to inbound traffic.
az vm open-port -g MyResourceGroup -n MyVm --port '*'Open a range of ports on a VM to inbound traffic with the highest priority.
az vm open-port -g MyResourceGroup -n MyVm --port 80-100 --priority 100Open ports 555, 557, 558, and 559 to inbound traffic with the highest priority.
az vm open-port -g MyResourceGroup -n MyVm --port 555,557-559 --priority 100Open all ports for all VMs in a resource group.
az vm open-port --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv) --port '*'Required Parameters
The port or port range (ex: 80-100) to open inbound traffic to. Use '*' to allow traffic to all ports. Use comma separated values to specify more than one port or port range.
Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Allow inbound traffic on the subnet instead of the NIC.
| Property | Value | 
|---|---|
| Default value: | False | 
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the virtual machine to open inbound traffic on.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the network security group to create if one does not exist. Ignored if an NSG already exists.
Rule priority, between 100 (highest priority) and 4096 (lowest priority). Must be unique for each rule in the collection.
| Property | Value | 
|---|---|
| Default value: | 900 | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm perform-maintenance
The operation to perform maintenance on a virtual machine.
az vm perform-maintenance [--ids]
                          [--name --vm-name]
                          [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
                          [--resource-group]
                          [--subscription]Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm reapply
Reapply VMs.
az vm reapply [--ids]
              [--name --vm-name]
              [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
              [--resource-group]
              [--subscription]Examples
Reapply a VM.
az vm reapply -g MyResourceGroup -n MyVmReapply all VMs in a resource group.
az vm reapply --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm redeploy
Redeploy an existing VM.
az vm redeploy [--ids]
               [--name --vm-name]
               [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
               [--resource-group]
               [--subscription]Examples
Redeploy a VM.
az vm redeploy -g MyResourceGroup -n MyVmRedeploy all VMs in a resource group.
az vm redeploy --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm reimage
Reimage (upgrade the operating system) a virtual machine.
Reimage (upgrade the operating system) a virtual machine which don't have a ephemeral OS disk, for virtual machines who have a ephemeral OS disk the virtual machine is reset to initial state. NOTE: The retaining of old OS disk depends on the value of deleteOption of OS disk. If deleteOption is detach, the old OS disk will be preserved after reimage. If deleteOption is delete, the old OS disk will be deleted after reimage. The deleteOption of the OS disk should be updated accordingly before performing the reimage.
az vm reimage [--admin-password]
              [--custom-data]
              [--exact-version]
              [--ids]
              [--name --vm-name]
              [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
              [--resource-group]
              [--subscription]
              [--temp-disk {0, 1, f, false, n, no, t, true, y, yes}]Examples
Reimage a virtual machine.
az vm reimage --name MyVm --resource-group MyResourceGroup --admin-password MyPassword --custom-data "dGVzdA==" --temp-disk false --exact-version 0.1Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Specifies the password of the administrator account.
| Property | Value | 
|---|---|
| Parameter group: | OsProfile Arguments | 
Specifies a base-64 encoded string of custom data.
| Property | Value | 
|---|---|
| Parameter group: | OsProfile Arguments | 
Specifies in decimal number, the version the OS disk should be reimaged to. If exact version is not provided, the OS disk is reimaged to the existing version of OS Disk.
| Property | Value | 
|---|---|
| Parameter group: | Parameters Arguments | 
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Specifies whether to reimage temp disk. Default value: false. Note: This temp disk reimage parameter is only supported for VM/VMSS with Ephemeral OS disk.
| Property | Value | 
|---|---|
| Parameter group: | Parameters Arguments | 
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm resize
Update a VM's size.
az vm resize --size
             [--ids]
             [--name]
             [--no-wait]
             [--resource-group]
             [--subscription]Examples
Resize a VM.
az vm resize -g MyResourceGroup -n MyVm --size Standard_DS3_v2Resize all VMs in a resource group.
az vm resize --size Standard_DS3_v2 --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Required Parameters
The VM size.
| Property | Value | 
|---|---|
| Value from: | az vm list-vm-resize-options | 
Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Default value: | False | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm restart
Restart VMs.
az vm restart [--force]
              [--ids]
              [--name]
              [--no-wait]
              [--resource-group]
              [--subscription]Examples
Restart a VM.
az vm restart -g MyResourceGroup -n MyVmRestart all VMs in a resource group.
az vm restart --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Force the VM to restart by redeploying it. Use if the VM is unresponsive.
| Property | Value | 
|---|---|
| Default value: | False | 
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Default value: | False | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm show
Get the details of a VM.
az vm show [--ids]
           [--include-user-data]
           [--name]
           [--resource-group]
           [--show-details]
           [--subscription]Examples
Show information about a VM.
az vm show -g MyResourceGroup -n MyVm -dGet the details for all VMs in a resource group.
az vm show -d --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Include the user data properties in the query result.
| Property | Value | 
|---|---|
| Default value: | False | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Show public ip address, FQDN, and power states. command will run slow.
| Property | Value | 
|---|---|
| Default value: | False | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm simulate-eviction
Simulate the eviction of a Spot VM.
az vm simulate-eviction [--ids]
                        [--name --vm-name]
                        [--resource-group]
                        [--subscription]Examples
Simulate the eviction of a Spot VM.
az vm simulate-eviction --resource-group MyResourceGroup --name MyVmOptional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm start
Start a stopped VM.
az vm start [--ids]
            [--name --vm-name]
            [--no-wait {0, 1, f, false, n, no, t, true, y, yes}]
            [--resource-group]
            [--subscription]Examples
Start a stopped VM.
az vm start -g MyResourceGroup -n MyVmStart all VMs in a resource group.
az vm start --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Start a stopped VM.
az vm start --name MyVm --no-wait --resource-group MyResourceGroupOptional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Accepted values: | 0, 1, f, false, n, no, t, true, y, yes | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm stop
Power off (stop) a running VM.
The VM will continue to be billed. To avoid this, you can deallocate the VM through "az vm deallocate".
az vm stop [--ids]
           [--name]
           [--no-wait]
           [--resource-group]
           [--skip-shutdown]
           [--subscription]Examples
Power off (stop) a running VM.
az vm stop --resource-group MyResourceGroup --name MyVmPower off a running VM without shutting down.
az vm stop --resource-group MyResourceGroup --name MyVm --skip-shutdownPower off VMs in a resource group.
az vm stop --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Default value: | False | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Skip shutdown and power-off immediately.
| Property | Value | 
|---|---|
| Default value: | False | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm update
Update the properties of a VM.
Update VM objects and properties using paths that correspond to 'az vm show'.
az vm update [--add]
             [--additional-events --additional-scheduled-events {false, true}]
             [--align-regional-disks --align-regional-disks-to-vm-zone {false, true}]
             [--capacity-reservation-group --crg]
             [--disk-caching]
             [--disk-controller-type {NVMe, SCSI}]
             [--enable-hibernation {false, true}]
             [--enable-proxy-agent {false, true}]
             [--enable-reboot --enable-user-reboot-scheduled-events {false, true}]
             [--enable-redeploy --enable-user-redeploy-scheduled-events {false, true}]
             [--enable-secure-boot {false, true}]
             [--enable-vtpm {false, true}]
             [--ephemeral-os-disk-placement --ephemeral-placement {CacheDisk, NvmeDisk, ResourceDisk}]
             [--force-string]
             [--host]
             [--host-group]
             [--ids]
             [--imds-access-control-profile-reference-id --imds-profile-id]
             [--imds-mode {Audit, Enforce}]
             [--key-incarnation-id]
             [--license-type {None, RHEL_BASE, RHEL_BASESAPAPPS, RHEL_BASESAPHA, RHEL_BYOS, RHEL_ELS_6, RHEL_EUS, RHEL_SAPAPPS, RHEL_SAPHA, SLES, SLES_BYOS, SLES_HPC, SLES_SAP, SLES_STANDARD, UBUNTU, UBUNTU_PRO, Windows_Client, Windows_Server}]
             [--max-price]
             [--name]
             [--no-wait]
             [--os-disk]
             [--ppg]
             [--priority {Low, Regular, Spot}]
             [--proxy-agent-mode {Audit, Enforce}]
             [--remove]
             [--resource-group]
             [--security-type {ConfidentialVM, Standard, TrustedLaunch}]
             [--set]
             [--size]
             [--subscription]
             [--ultra-ssd-enabled {false, true}]
             [--user-data]
             [--v-cpus-available]
             [--v-cpus-per-core]
             [--wire-server-access-control-profile-reference-id --wire-server-profile-id]
             [--wire-server-mode {Audit, Enforce}]
             [--workspace]
             [--write-accelerator]Examples
Add or update a tag.
az vm update -n name -g group --set tags.tagName=tagValueRemove a tag.
az vm update -n name -g group --remove tags.tagNameSet the primary NIC of a VM.
az vm update -n name -g group --set networkProfile.networkInterfaces[1].primary=false networkProfile.networkInterfaces[0].primary=trueAdd a new non-primary NIC to a VM.
az vm update -n name -g group --add networkProfile.networkInterfaces primary=false id={NIC_ID}Remove the fourth NIC from a VM.
az vm update -n name -g group --remove networkProfile.networkInterfaces 3Add an existing VM to a dedicated host
az vm deallocate -n name -g group
az vm update -n name -g group --host my-host
az vm start -n name -g groupAdd an existing VM to a dedicated host group
az vm deallocate -n name -g group
az vm update -n name -g group --host-group my-host-group
az vm start -n name -g groupOptional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Add an object to a list of objects by specifying a path and key value pairs.  Example: --add property.listProperty <key=value, string or JSON string>.
| Property | Value | 
|---|---|
| Parameter group: | Generic Update Arguments | 
| Default value: | [] | 
The configuration parameter used while creating event grid and resource graph scheduled event setting.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Specify whether the regional disks should be aligned/moved to the VM zone. This is applicable only for VMs with placement property set. Please note that this change is irreversible.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
The ID or name of the capacity reservation group that is used to allocate. Pass in "None" to disassociate the capacity reservation group. Please note that if you want to delete a VM/VMSS that has been associated with capacity reservation group, you need to disassociate the capacity reservation group first.
Use singular value to apply across, or specify individual disks, e.g. 'os=ReadWrite 0=None 1=ReadOnly' should enable update os disk and 2 data disks.
Specify the disk controller type configured for the VM or VMSS.
| Property | Value | 
|---|---|
| Parameter group: | Storage Arguments | 
| Accepted values: | NVMe, SCSI | 
The flag that enable or disable hibernation capability on the VM.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Specify whether metadata security protoco (proxy agent) feature should be enabled on the virtual machine or virtual machine scale set.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
The configuration parameter used while publishing scheduled events additional publishing targets.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
The configuration parameter used while creating user initiated redeploy scheduled event setting creation.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Enable secure boot.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Enable vTPM.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
Only applicable when used with --size. Allows you to choose the Ephemeral OS disk provisioning location.
| Property | Value | 
|---|---|
| Accepted values: | CacheDisk, NvmeDisk, ResourceDisk | 
When using 'set' or 'add', preserve string literals instead of attempting to convert to JSON.
| Property | Value | 
|---|---|
| Parameter group: | Generic Update Arguments | 
| Default value: | False | 
Resource ID of the dedicated host that the VM will reside in. --host and --host-group can't be used together. You should deallocate the VM before update, and start the VM after update. Please check out help for more examples.
| Property | Value | 
|---|---|
| Parameter group: | Dedicated Host Arguments | 
Name or resource ID of the dedicated host group that the VM will reside in. --host and --host-group can't be used together. You should deallocate the VM before update, and start the VM after update. Please check out help for more examples.
| Property | Value | 
|---|---|
| Parameter group: | Dedicated Host Arguments | 
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Specify the access control profile version resource id resource id of imds.
Specify the mode that proxy agent will execute on if the feature is enabled.
| Property | Value | 
|---|---|
| Accepted values: | Audit, Enforce | 
Increase the value of this property allows user to reset the key used for securing communication channel between guest and host.
Specifies that the Windows image or disk was licensed on-premises. To enable Azure Hybrid Benefit for Windows Server, use 'Windows_Server'. To enable Multi-tenant Hosting Rights for Windows 10, use 'Windows_Client'. For more information see the Azure Windows VM online docs.
| Property | Value | 
|---|---|
| Accepted values: | None, RHEL_BASE, RHEL_BASESAPAPPS, RHEL_BASESAPHA, RHEL_BYOS, RHEL_ELS_6, RHEL_EUS, RHEL_SAPAPPS, RHEL_SAPHA, SLES, SLES_BYOS, SLES_HPC, SLES_SAP, SLES_STANDARD, UBUNTU, UBUNTU_PRO, Windows_Client, Windows_Server | 
The maximum price (in US Dollars) you are willing to pay for a Spot VM/VMSS. -1 indicates that the Spot VM/VMSS should not be evicted for price reasons.
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Do not wait for the long-running operation to finish.
| Property | Value | 
|---|---|
| Default value: | False | 
Managed OS disk ID or name to swap to.
The name or ID of the proximity placement group the VM should be associated with.
Priority. Use 'Spot' to run short-lived workloads in a cost-effective way. 'Low' enum will be deprecated in the future. Please use 'Spot' to deploy Azure spot VM and/or VMSS. Default to Regular.
| Property | Value | 
|---|---|
| Accepted values: | Low, Regular, Spot | 
Option '--proxy-agent-mode' has been deprecated and will be removed in a future release. Use '--wire-server-mode' instead.
Specify the mode that proxy agent will execute on if the feature is enabled.
| Property | Value | 
|---|---|
| Accepted values: | Audit, Enforce | 
Remove a property or an element from a list.  Example: --remove property.list <indexToRemove> OR --remove propertyToRemove.
| Property | Value | 
|---|---|
| Parameter group: | Generic Update Arguments | 
| Default value: | [] | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Specify the security type of the virtual machine. The value Standard can be used if subscription has feature flag UseStandardSecurityType registered under Microsoft.Compute namespace. Refer to https://free.blessedness.top/en-us/azure/azure-resource-manager/management/preview-features for steps to enable required feature.
| Property | Value | 
|---|---|
| Accepted values: | ConfidentialVM, Standard, TrustedLaunch | 
Update an object by specifying a property path and value to set.  Example: --set property1.property2=<value>.
| Property | Value | 
|---|---|
| Parameter group: | Generic Update Arguments | 
| Default value: | [] | 
The new size of the virtual machine. See https://azure.microsoft.com/pricing/details/virtual-machines/ for size info.
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Enables or disables the capability to have 1 or more managed data disks with UltraSSD_LRS storage account.
| Property | Value | 
|---|---|
| Accepted values: | false, true | 
UserData for the VM. It can be passed in as file or string. If empty string is passed in, the existing value will be deleted.
Specify the number of vCPUs available.
Specify the ratio of vCPU to physical core. Setting this property to 1 also means that hyper-threading is disabled.
Specify the access control profile version resource id of wire server.
Specify the mode that proxy agent will execute on if the feature is enabled.
| Property | Value | 
|---|---|
| Accepted values: | Audit, Enforce | 
Name or ID of Log Analytics Workspace. If you specify the workspace through its name, the workspace should be in the same resource group with the vm, otherwise a new workspace will be created.
| Property | Value | 
|---|---|
| Parameter group: | Monitor Arguments | 
Enable/disable disk write accelerator. Use singular value 'true/false' to apply across, or specify individual disks, e.g.'os=true 1=true 2=true' for os disk and data disks with lun of 1 & 2.
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
az vm wait
Place the CLI in a waiting state until a condition of the VM is met.
az vm wait [--created]
           [--custom]
           [--deleted]
           [--exists]
           [--ids]
           [--interval]
           [--name]
           [--resource-group]
           [--subscription]
           [--timeout]
           [--updated]Examples
Wait until a VM is created.
az vm wait -g MyResourceGroup -n MyVm --createdWait until all VMs in a resource group are deleted.
az vm wait --deleted --ids $(az vm list -g MyResourceGroup --query "[].id" -o tsv)Optional Parameters
The following parameters are optional, but depending on the context, one or more might become required for the command to execute successfully.
Wait until created with 'provisioningState' at 'Succeeded'.
| Property | Value | 
|---|---|
| Parameter group: | Wait Condition Arguments | 
| Default value: | False | 
Wait until the condition satisfies a custom JMESPath query. E.g. provisioningState!='InProgress', instanceView.statuses[?code=='PowerState/running'].
| Property | Value | 
|---|---|
| Parameter group: | Wait Condition Arguments | 
Wait until deleted.
| Property | Value | 
|---|---|
| Parameter group: | Wait Condition Arguments | 
| Default value: | False | 
Wait until the resource exists.
| Property | Value | 
|---|---|
| Parameter group: | Wait Condition Arguments | 
| Default value: | False | 
One or more resource IDs (space-delimited). It should be a complete resource ID containing all information of 'Resource Id' arguments. You should provide either --ids or other 'Resource Id' arguments.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Polling interval in seconds.
| Property | Value | 
|---|---|
| Parameter group: | Wait Condition Arguments | 
| Default value: | 30 | 
The name of the Virtual Machine. You can configure the default using az configure --defaults vm=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name of resource group. You can configure the default group using az configure --defaults group=<name>.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Name or ID of subscription. You can configure the default subscription using az account set -s NAME_OR_ID.
| Property | Value | 
|---|---|
| Parameter group: | Resource Id Arguments | 
Maximum wait in seconds.
| Property | Value | 
|---|---|
| Parameter group: | Wait Condition Arguments | 
| Default value: | 3600 | 
Wait until updated with provisioningState at 'Succeeded'.
| Property | Value | 
|---|---|
| Parameter group: | Wait Condition Arguments | 
| Default value: | False | 
Global Parameters
Increase logging verbosity to show all debug logs.
| Property | Value | 
|---|---|
| Default value: | False | 
Show this help message and exit.
Only show errors, suppressing warnings.
| Property | Value | 
|---|---|
| Default value: | False | 
Output format.
| Property | Value | 
|---|---|
| Default value: | json | 
| Accepted values: | json, jsonc, none, table, tsv, yaml, yamlc | 
JMESPath query string. See http://jmespath.org/ for more information and examples.
Increase logging verbosity. Use --debug for full debug logs.
| Property | Value | 
|---|---|
| Default value: | False |