Resources op schaal verwijderen met behulp van de Azure CLI
Als Azure-resourcemanager moet u vaak meerdere Azure-resources verwijderen bij het afbreken van een oude omgeving. Sommige CLI devTest-omgevingen hebben ook een periodieke opschoning nodig, zodat er geen kosten in rekening worden gebracht voor tijdelijke Azure-resources die langer zijn gebleven.
In dit Azure CLI-voorbeeld leert u het volgende:
- Meerdere Azure-resources verwijderen uit een script
- Voortgang van logboekscript naar een lokaal TXT-bestand
Dit voorbeeldscript is getest in Azure Cloud Shell in een Bash-omgeving. Dit script is ook getest in Ubuntu 22.04.3 LTS met behulp van Windows Terminal.
Azure-resources filteren op naam verwijderen
Gebruik dit script om resourcegroepen weer te geven en te verwijderen die beginnen met een bepaald woord.
# 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
Azure-resources filteren op aanmaakdatum verwijderen
Gebruik dit script om opslagaccounts weer te geven en te verwijderen die zijn gemaakt binnen een datumbereik.
# 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
Alle Azure-resources van een type verwijderen
Alle virtuele machines in een resourcegroep verwijderen
# Set your resource group variable
rgName=<msdocs-rg-0000000>
az group delete -n $rgName --force-deletion-types Microsoft.Compute/virtualMachines