Delen via


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

Zie ook