Löschen von Ressourcen im großen Maßstab mithilfe der Azure CLI

Als Azure-Ressourcenmanager müssen Sie häufig mehrere Azure-Ressourcen löschen, wenn Sie eine alte Umgebung abreißen. Einige CLI DevTest-Umgebungen benötigen außerdem eine regelmäßige sauber, sodass keine Gebühren für temporäre Azure-Ressourcen anfallen, die länger verharren.

In diesem Azure CLI-Beispiel lernen Sie Folgendes:

  • Löschen mehrerer Azure-Ressourcen aus einem Skript
  • Protokollskriptstatus bei einer lokalen TXT-Datei

Dieses Beispielskript wurde in Azure Cloud Shell in einer Bash-Umgebung getestet. Dieses Skript wurde auch erfolgreich in Ubuntu 22.04.3 LTS mit Windows-Terminal getestet.

Löschen der Azure-Ressourcenfilterung nach Name

Verwenden Sie dieses Skript zum Auflisten und Löschen von Ressourcengruppen, die mit einem bestimmten Wort beginnen.

# Set your subscription
subscriptionID=00000000-0000-0000-0000-00000000
az account set --subscription $subscriptionID

# Set your log file location
logFileLocation="myLogName.txt"

# Get the name of all resource groups that start with 'msdocs'
az group list --query "[?starts_with(name, 'msdocs') == \`true\`].name" -o table

# Delete resource groups without a confirmation prompt (--yes)
# Do not wait for the operation to finish (--no-wait)
echo "Deleting resource groups">$logFileLocation
for rgList in $(az group list --query "[?starts_with(name, 'msdocs') == \`true\`].name" -o tsv); 
do
    echo "deleting resource group $rgList">>$logFileLocation
    az group delete --name $rgList --yes --no-wait
done

# read your log file with Linux "cat" command
clear
cat $logFileLocation

Löschen der Azure-Ressourcenfilterung nach Erstellungsdatum

Verwenden Sie dieses Skript zum Auflisten und Löschen von Speicherkonten, die innerhalb eines Datumsbereichs erstellt wurden.

# Set your log file location
logFileLocation="myLogName.txt"

# Set your resource group variable
rgName=<msdocs-rg-0000000>

# Get a list of Azure storage accounts that were created in the last 30 days. Return the results as a table.
saDate=$(date +%F -d "-30days")
az storage account list --resource-group $rgName \
                        --query "[?creationTime >='$saDate'].{saName:name, createdTimeStamp:creationTime}" \
                        --output table

# Delete storage accounts without a confirmation prompt (--yes).
# Do not wait for the operation to finish (--no-wait)
echo "Deleting storage accounts">$logFileLocation
for saList in $(az storage account list --resource-group $rgName \
                        --query "[?creationTime >='$saDate'].{saName:name, createdTimeStamp:creationTime}" \
                        --output tsv);
do
    echo "deleting storage account $saList">>$logFileLocation
    az storage account delete --ids $saList --yes --no-wait
done

# read your log file with Linux "cat" command
clear
cat $logFileLocation

Löschen aller Azure-Ressourcen eines Typs

Löschen aller virtuellen Computer in einer Ressourcengruppe

# Set your resource group variable
rgName=<msdocs-rg-0000000>

az group delete -n $rgName --force-deletion-types Microsoft.Compute/virtualMachines

Weitere Informationen