Compartilhar via


Localizar e excluir discos gerenciados e não gerenciados desanexados do Azure usando a CLI do Azure

Aplica-se a: ✔️ VMs do Linux ✔️ Conjuntos de dimensionamento flexíveis

Quando você exclui uma VM (máquina virtual) no Azure, por padrão, nenhum disco anexado à máquina virtual é excluído. Esse recurso ajuda a evitar a perda de dados devido à exclusão não intencional de VMs. Depois que uma VM for excluída, você continuará a pagar pelos discos desanexados. Este artigo mostra como localizar e excluir discos desanexados e reduzir custos desnecessários.

Observação

Você pode usar o comando az disk show para obter o LastOwnershipUpdateTime para qualquer disco. Essa propriedade representa quando o estado do disco foi atualizado pela última vez. Para um disco não anexado, isso mostra a hora em que o disco foi desanexado. Essa propriedade fica em branco para discos recém-criados, até que seu estado seja alterado.

Discos gerenciados: Localizar e excluir discos desanexados

O script a seguir procura discos gerenciados desanexados examinando o valor da propriedade ManagedBy. Quando um disco gerenciado é anexado a uma VM, a propriedade ManagedBy contém a ID de recurso da VM. Quando um disco gerenciado é desanexado, a propriedade ManagedBy é nula. O script examina todos os discos gerenciados em uma assinatura do Azure. Quando o script localiza um disco gerenciado com a propriedade ManagedBy definida como null, o script determina que o disco está desanexado.

Importante

Primeiro, execute o script definindo a variável deleteUnattachedDisks como 0. Essa ação permite localizar e exibir todos os discos gerenciados desanexados.

Depois de examinar todos os discos desanexados, execute o script novamente e defina a variável deleteUnattachedDisks como 1. Essa ação permite excluir todos os discos gerenciados desanexados.

# Set deleteUnattachedDisks=1 if you want to delete unattached Managed Disks
# Set deleteUnattachedDisks=0 if you want to see the Id of the unattached Managed Disks
deleteUnattachedDisks=0
unattachedDiskIds=$(az disk list --query '[?managedBy==`null`].[id]' -o tsv)
for id in ${unattachedDiskIds[@]}
do
    if (( $deleteUnattachedDisks == 1 ))
    then

        echo "Deleting unattached Managed Disk with Id: "$id
        az disk delete --ids $id --yes
        echo "Deleted unattached Managed Disk with Id: "$id

    else
        echo $id
    fi
done

Discos não gerenciados: Localizar e excluir discos desanexados

Discos não gerenciados são arquivos VHD armazenados como blobs de páginas nas Contas de Armazenamento do Microsoft Azure. O script a seguir procura discos não gerenciados desanexados (blobs de página) examinando o valor da propriedade LeaseStatus. Se um disco não gerenciado estiver conectado a uma máquina virtual, a propriedadeLeaseStatus estará configurada como Locked. Quando um disco não gerenciado é desanexado, a propriedade LeaseStatus está definida como Unlocked. O script examina todos os discos não gerenciados em todas as contas de armazenamento do Azure em uma assinatura do Azure. Quando o script localiza um disco não gerenciado com uma propriedade LeaseStatus propriedade definida como Unlocked, o script determina que o disco está desanexado.

Importante

Primeiro, execute o script definindo a variável deleteUnattachedVHDs como 0. Essa ação permite localizar e exibir todos os VHDs não gerenciados desanexados.

Depois de examinar todos os discos desanexados, execute o script novamente e defina a variável deleteUnattachedVHDs como 1. Essa ação permite excluir todos os VHDs não gerenciados desanexados.

# Set deleteUnattachedVHDs=1 if you want to delete unattached VHDs
# Set deleteUnattachedVHDs=0 if you want to see the details of the unattached VHDs
deleteUnattachedVHDs=0
storageAccountIds=$(az storage account list --query [].[id] -o tsv)
for id in ${storageAccountIds[@]}
do
    connectionString=$(az storage account show-connection-string --ids $id --query connectionString -o tsv)
    containers=$(az storage container list --connection-string $connectionString --query [].[name] -o tsv)

    for container in ${containers[@]}
    do 
        
        blobs=$(az storage blob list --show-next-marker -c $container --connection-string $connectionString --query "[?properties.blobType=='PageBlob' && ends_with(name,'.vhd')].[name]" -o tsv)
        
        for blob in ${blobs[@]}
        do
            leaseStatus=$(az storage blob show -n $blob -c $container --connection-string $connectionString --query "properties.lease.status" -o tsv)
            
            if [ "$leaseStatus" == "unlocked" ]
            then 

                if (( $deleteUnattachedVHDs == 1 ))
                then 

                    echo "Deleting VHD: "$blob" in container: "$container" in storage account: "$id

                    az storage blob delete --delete-snapshots include  -n $blob -c $container --connection-string $connectionString

                    echo "Deleted VHD: "$blob" in container: "$container" in storage account: "$id
                else
                    echo "StorageAccountId: "$id" container: "$container" VHD: "$blob
                fi

            fi
        done
    done
done 

Próximas etapas

Para obter mais informações, confira Excluir uma conta de armazenamento.