Freigeben über


Verschieben von Azure-Ressourcen in eine neue Ressourcengruppe oder ein neues Abonnement

In diesem Artikel wird erläutert, wie Azure-Ressourcen zwischen Ressourcengruppen verschoben werden, unabhängig davon, ob sie sich innerhalb desselben Abonnements oder in verschiedenen Abonnements befinden. Wenn die Verschiebung mehrere Abonnements umfasst, müssen diese Abonnements zum selben Microsoft Entra ID-Mandanten gehören. Sie können die Verschiebung mithilfe von Tools wie dem Azure-Portal, Azure PowerShell, der Azure-Befehlszeilenschnittstelle, der REST-API oder Python durchführen.

Während des Verschiebens werden sowohl die Quell- als auch die Zielressourcengruppen gesperrt. Dies bedeutet, dass Sie während des Verschiebens keine Ressourcen innerhalb dieser Ressourcengruppen erstellen, löschen oder aktualisieren können. Die vorhandenen Ressourcen bleiben jedoch vollständig betriebsbereit. Wenn Sie beispielsweise eine VM zwischen zwei Ressourcengruppen verschieben, kann die VM nicht gelöscht werden, und ihre Eigenschaften (z. B. die VM-Größe) können während des Verschiebens nicht geändert werden. Trotzdem wird die VM weiterhin normal ausgeführt, und bei den Diensten, die sie benötigen, tritt keine zusätzliche Downtime auf. Die Sperre kann bis zu vier Stunden dauern, aber die meisten Verschiebungen werden schneller abgeschlossen, sodass auch die Sperre entsprechend früher aufgehoben wird.

In der Anforderung zum Verschieben sollten nur Ressourcen auf oberster Ebene (übergeordnete Ressourcen) angegeben werden. Untergeordnete Ressourcen werden automatisch zusammen mit ihrem übergeordneten Ressourcen verschoben und können nicht unabhängig verschoben werden. Beispielsweise werden beim Verschieden der übergeordneten Ressource Microsoft.Compute/virtualMachines auch ihre untergeordneten Ressource (z. B. Microsoft.Compute/virtualMachines/extensions) mit verschoben. Die untergeordnete Ressource kann jedoch nicht allein verschoben werden.

Beim Verschieben einer Ressource bleiben ihre Abhängigkeiten mit untergeordneten Ressourcen erhalten. Abhängigkeiten mit anderen Ressourcen können jedoch unterbrochen werden und erfordern dann eine Neukonfiguration. Durch das Verschieben einer Ressource wird nur die zugeordnete Ressourcengruppe geändert, der physische Standort der Ressource ändert sich nicht.

Hinweis

Azure-Ressourcen können nicht verschoben werden, wenn in der Quell- oder Zielressourcengruppe oder im Quell- oder Zielabonnement eine Schreibschutzsperre vorhanden ist.

Geänderte Ressourcen-ID

Wenn Sie eine Ressource verschieben, ändern Sie ihre Ressourcen-ID. Das Standardformat für eine Ressourcen-ID ist /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}. Wenn Sie eine Ressource in eine neue Ressourcengruppe oder ein Abonnement verschieben, ändern Sie einen oder mehrere Werte in dem Pfad.

Wenn Sie die Ressourcen-ID an einer beliebigen Stelle verwenden, müssen Sie ihren Wert ändern. Wenn Sie z. B. im Portal ein benutzerdefiniertes Dashboard verwenden, das auf eine Ressourcen-ID verweist, müssen Sie diesen Wert aktualisieren. Suchen Sie nach allen Skripten oder Vorlagen, die für die neue Ressourcen-ID aktualisiert werden müssen.

Checkliste vor dem Verschieben von Ressourcen

Vor dem Verschieben einer Ressource müssen einige wichtige Schritte ausgeführt werden. Indem Sie diese Bedingungen überprüfen, können Sie Fehler vermeiden.

  1. Quellen- und Zielabonnements müssen aktiv sein. Wenn beim Aktivieren eines Kontos, das deaktiviert wurde, Schwierigkeiten auftreten, erstellen Sie eine Azure-Supportanfrage. Wählen Sie Abonnementverwaltung als Problemtyp aus.

  2. Quell- und Zielabonnement müssen im selben Microsoft Entra-Mandanten vorhanden sein. Um zu überprüfen, ob beide Abonnements die gleiche Mandanten-ID aufweisen, verwenden Sie Azure PowerShell oder die Azure-Befehlszeilenschnittstelle.

    az account show --subscription <your-source-subscription> --query tenantId
    az account show --subscription <your-destination-subscription> --query tenantId
    

    Wenn die Mandanten-IDs für das Quell- und das Zielabonnement nicht gleich sind, verwenden Sie die folgenden Methoden, um die Mandanten-IDs aufeinander abzustimmen:

  3. Wenn Sie versuchen, Ressourcen zu oder von einem Cloud Solution Provider (CSP)-Partner zu verschieben, finden Sie weitere Informationen unter Übertragen von Azure-Abonnements zwischen Abonnenten und CSPs.

  4. Die zu verschiebenden Ressourcen müssen den Verschiebevorgang unterstützen. Eine Liste der Ressourcen, die das Verschieben unterstützen, finden Sie unter Unterstützung des Verschiebevorgangs für Ressourcen.

  5. Für einige Dienste gelten bestimmte Einschränkungen oder Anforderungen beim Verschieben von Ressourcen. Wenn Sie einen der folgenden Dienste verschieben möchten, überprüfen Sie diese Anleitung vor dem Verschieben.

  6. Das Zielabonnement muss für den Ressourcenanbieter der verschobenen Ressource registriert sein. Andernfalls erhalten Sie eine Fehlermeldung, die besagt, dass das Abonnement nicht für einen Ressourcentyp registriert ist. Dieser Fehler kann auftreten, wenn eine Ressource in ein neues Abonnement verschoben wird, dieses aber noch nie mit diesem Ressourcentyp verwendet wurde.

    So rufen Sie den Registrierungsstatus ab

    az account set -s <destination-subscription-name-or-id>
    az provider list --query "[].{Provider:namespace, Status:registrationState}" --out table
    

    So registrieren Sie einen Ressourcenanbieter

    az provider register --namespace Microsoft.Batch
    
  7. Überprüfen Sie vor dem Verschieben der Ressource die Abonnementkontingente für das Abonnement, zu dem Sie die Ressourcen verschieben. Wenn ein Abonnement durch das Verschieben von Ressourcen seine Grenzwerte überschreitet, müssen Sie prüfen, ob Sie eine Erhöhung des Kontingents anfordern können. Eine vollständige Liste zu diesen Einschränkungen und Informationen zur Anforderung einer Kontingenterhöhung finden Sie unter Einschränkungen für Azure-Abonnements und Dienste, Kontingente und Einschränkungen.

  8. Das Konto, das die Ressourcen verschiebt, muss mindestens über folgende Berechtigungen verfügen:

    • Microsoft.Resources/subscriptions/resourceGroups/moveResources/action für die Quellressourcengruppe.
    • Microsoft.Resources/subscriptions/resourceGroups/write für die Zielressourcengruppe.
  9. Wenn Sie eine Ressource verschieben, der eine Azure-Rolle direkt zugewiesen ist (oder eine untergeordnete Ressource), wird die Rollenzuweisung nicht verschoben und verwaist. Nach der Verschiebung müssen Sie die Rollenzuweisung erneut erstellen. Letztendlich wird die verwaiste Rollenzuweisung automatisch entfernt, wir empfehlen jedoch, die Rollenzuweisung vor dem Verschieben zu entfernen.

    Informationen zum Verwalten von Rollenzuweisungen finden Sie unter Auflisten von Azure-Rollenzuweisungen und Zuweisen von Azure-Rollen über das Azure-Portal.

  10. Für eine abonnementübergreifende Verschiebung müssen die Ressource und die davon abhängigen Ressourcen in derselben Ressourcengruppe angeordnet sein und zusammen verschoben werden. Für eine VM mit verwalteten Datenträgern müssen die VM und die verwalteten Datenträger beispielsweise gemeinsam und auch zusammen mit den anderen abhängigen Ressourcen verschoben werden.

    Wenn Sie eine Ressource in ein neues Abonnement verschieben, sollten Sie überprüfen, ob die Ressource über abhängige Ressourcen verfügt und ob diese sich in derselben Ressourcengruppe befinden. Wenn sich die Ressourcen nicht in derselben Ressourcengruppe befinden, sollten Sie überprüfen, ob die Ressourcen in derselben Ressourcengruppe kombiniert werden können. Wenn ja, müssen Sie alle Ressourcen in derselben Ressourcengruppe vereinen, indem Sie übergreifend für die Ressourcengruppen einen Verschiebungsvorgang durchführen.

    Weitere Informationen finden Sie unter Szenario für eine abonnementübergreifende Verschiebung.

Szenario für eine abonnementübergreifende Verschiebung

Das Verschieben von Ressourcen aus einem Abonnement in ein anderes ist ein dreistufiger Prozess:

Diagramm, das den dreistufigen Prozess des Verschiebens von Ressourcen zwischen Abonnements zeigt.

Der Einfachheit halber verwenden wir hier nur eine abhängige Ressource.

  • Schritt 1: Wenn abhängige Ressourcen auf unterschiedliche Ressourcengruppen verteilt sind, müssen Sie diese zuerst in einer Ressourcengruppe zusammenfassen.
  • Schritt 2: Verschieben Sie die Ressource und die abhängigen Ressourcen zusammen aus dem Quellabonnement in das Zielabonnement.
  • Schritt 3: Optional können Sie die abhängigen Ressourcen auf unterschiedliche Ressourcengruppen im Zielabonnement verteilen.

Verschieben von Ressourcen

Verwenden des Portals

Wählen Sie zum Verschieben von Ressourcen die Ressourcengruppe aus, die diese Ressourcen enthält.

Auswählen der Ressourcen, die Sie verschieben möchten Aktivieren Sie das Kontrollkästchen oben in der Liste, um alle Ressourcen zu verschieben. Oder wählen Sie Ressourcen einzeln aus.

Screenshot: Im Azure-Portal wird die zu verschiebende Ressource ausgewählt.

Wählen Sie die Schaltfläche Verschieben aus.

Screenshot: Azure-Portal mit der Schaltfläche „Verschieben“ mit drei Optionen.

Diese Schaltfläche bietet Ihnen drei Optionen:

Wählen Sie aus, ob Sie die Ressource in eine neue Ressourcengruppe oder ein neues Abonnement verschieben.

Die Quellressourcengruppe wird automatisch festgelegt. Wählen Sie die Zielressourcengruppe aus. Wenn Sie zu einem neuen Abonnement umstiegen, geben Sie auch das Abonnement an. Wählen Sie Weiter aus.

Screenshot: Im Azure-Portal gibt der Benutzer die Zielressourcengruppe für den Verschiebevorgang an.

Das Portal überprüft, ob die Ressourcen verschoben werden können. Warten Sie, bis die Validierung abgeschlossen ist.

Screenshot: Im Azure-Portal wird der Überprüfungsprozess für den Verschiebevorgang angezeigt.

Wenn die Validierung erfolgreich abgeschlossen wurde, wählen Sie Weiter aus.

Bestätigen Sie, dass Sie Tools und Skripts für diese Ressourcen aktualisieren müssen. Um mit dem Verschieben der Ressourcen zu beginnen, wählen Sie Verschieben aus.

Screenshot: Im Azure-Portal bestätigt der Benutzer, dass die Tools und Skripte aktualisiert werden müssen, bevor der Verschiebevorgang gestartet wird.

Sobald das Verschieben abgeschlossen ist, werden Sie über das Ergebnis informiert.

Screenshot: Im Azure-Portal wird eine Benachrichtigung mit den Ergebnissen des Verschiebevorgangs angezeigt.

Mithilfe der Azure-Befehlszeilenschnittstelle

Überprüfen

Verwenden Sie den Befehl az resource invoke-action, um Ihre Verschiebeaktion zu testen, ohne die Ressourcen tatsächlich zu verschieben. Verwenden Sie diesen Befehl nur, wenn Sie die Ergebnisse vorab bestimmen müssen. Um diesen Vorgang ausführen zu können, benötigen Sie Folgendes:

  • Ressourcen-ID der Quellressourcengruppe
  • Ressourcen-ID der Zielressourcengruppe
  • Ressourcen-ID der einzelnen zu verschiebenden Ressourcen

Verwenden Sie im Anforderungstext \", um doppelte Anführungszeichen zu maskieren.

az resource invoke-action --action validateMoveResources \
  --ids "/subscriptions/{subscription-id}/resourceGroups/{source-rg}" \
  --request-body "{  \"resources\": [\"/subscriptions/{subscription-id}/resourceGroups/{source-rg}/providers/{resource-provider}/{resource-type}/{resource-name}\", \"/subscriptions/{subscription-id}/resourceGroups/{source-rg}/providers/{resource-provider}/{resource-type}/{resource-name}\", \"/subscriptions/{subscription-id}/resourceGroups/{source-rg}/providers/{resource-provider}/{resource-type}/{resource-name}\"],\"targetResourceGroup\":\"/subscriptions/{subscription-id}/resourceGroups/{destination-rg}\" }" 

Ausgabe bei erfolgreicher Validierung:

{} Finished .. 

Wenn die Validierung fehlschlägt, wird eine Fehlermeldung angezeigt, die beschreibt, warum die Ressourcen nicht verschoben werden können.

Move

Verwenden Sie zum Verschieben vorhandener Ressourcen in eine andere Ressourcengruppe oder ein anderes Abonnement den Befehl az resource move. Geben Sie im --ids-Parameter eine durch Leerzeichen getrennte Liste der zu verschiebenden Ressourcen-IDs an.

Im folgenden Beispiel wird veranschaulicht, wie mehrere Ressourcen in eine neue Ressourcengruppe verschoben werden. Dies funktioniert bei Verwendung der Azure CLI in einem Bash-Terminal.

webapp=$(az resource show -g OldRG -n ExampleSite --resource-type "Microsoft.Web/sites" --query id --output tsv)
plan=$(az resource show -g OldRG -n ExamplePlan --resource-type "Microsoft.Web/serverfarms" --query id --output tsv)
az resource move --destination-group newgroup --ids $webapp $plan

Im nächsten Beispiel wird gezeigt, wie die gleichen Befehle in einer PowerShell-Konsole ausgeführt werden.

$webapp=$(az resource show -g OldRG -n ExampleSite --resource-type "Microsoft.Web/sites" --query id --output tsv)
$plan=$(az resource show -g OldRG -n ExamplePlan --resource-type "Microsoft.Web/serverfarms" --query id --output tsv)
az resource move --destination-group newgroup --ids $webapp $plan

Um Ressourcen in ein neues Abonnement zu verschieben, geben Sie den Parameter--destination-subscription-id an.

Mithilfe von Azure PowerShell

Überprüfen

Verwenden Sie den Befehl Invoke-AzResourceAction, um Ihre Verschiebeaktion zu testen, ohne die Ressourcen tatsächlich zu verschieben. Verwenden Sie diesen Befehl nur, wenn Sie die Ergebnisse vorab bestimmen müssen.

$sourceName = "sourceRG"
$destinationName = "destinationRG"
$resourcesToMove = @("app1", "app2")

$sourceResourceGroup = Get-AzResourceGroup -Name $sourceName
$destinationResourceGroup = Get-AzResourceGroup -Name $destinationName

$resources = Get-AzResource -ResourceGroupName $sourceName | Where-Object { $_.Name -in $resourcesToMove }

Invoke-AzResourceAction -Action validateMoveResources `
  -ResourceId $sourceResourceGroup.ResourceId `
  -Parameters @{
  resources = $resources.ResourceId;  # Wrap in an @() array if providing a single resource ID string.
  targetResourceGroup = $destinationResourceGroup.ResourceId
  }

Wenn die Überprüfung erfolgreich ist, wird keine Ausgabe angezeigt. Wenn die Überprüfung jedoch fehlschlägt, wird eine Fehlermeldung mit den Gründen angezeigt, aus denen die Ressourcen nicht verschoben werden können.

Move

Verwenden Sie zum Verschieben vorhandener Ressourcen in eine andere Ressourcengruppe oder ein anderes Abonnement den Befehl Move-AzResource. Im folgenden Beispiel wird veranschaulicht, wie mehrere Ressourcen in eine neue Ressourcengruppe verschoben werden.

$sourceName = "sourceRG"
$destinationName = "destinationRG"
$resourcesToMove = @("app1", "app2")

$resources = Get-AzResource -ResourceGroupName $sourceName | Where-Object { $_.Name -in $resourcesToMove }

Move-AzResource -DestinationResourceGroupName $destinationName -ResourceId $resources.ResourceId

Um Ressourcen in ein neues Abonnement zu verschieben, schließen Sie einen Wert für den Parameter DestinationSubscriptionId ein.

Verwenden von Python

Überprüfen

Um Ihr Szenario für die Verschiebung zu testen, ohne die Ressourcen tatsächlich zu verschieben, verwenden Sie die Methode ResourceManagementClient.resources.begin_validate_move_resources. Verwenden Sie diese Methode nur, wenn Sie die Ergebnisse vorab bestimmen müssen.

import os
from azure.identity import AzureCliCredential
from azure.mgmt.resource import ResourceManagementClient

credential = AzureCliCredential()
subscription_id = os.environ["AZURE_SUBSCRIPTION_ID"]

resource_client = ResourceManagementClient(credential, subscription_id)

source_name = "sourceRG"
destination_name = "destinationRG"
resources_to_move = ["app1", "app2"]

destination_resource_group = resource_client.resource_groups.get(destination_name)

resources = [
  resource for resource in resource_client.resources.list_by_resource_group(source_name)
  if resource.name in resources_to_move
]

resource_ids = [resource.id for resource in resources]

validate_move_resources_result = resource_client.resources.begin_validate_move_resources(
  source_name,
  {
  "resources": resource_ids,
  "target_resource_group": destination_resource_group.id
  }
).result()

print("Validate move resources result: {}".format(validate_move_resources_result))

Wenn die Überprüfung erfolgreich ist, wird keine Ausgabe angezeigt. Wenn die Überprüfung jedoch fehlschlägt, wird eine Fehlermeldung mit den Gründen angezeigt, aus denen die Ressourcen nicht verschoben werden können.

Move

Verwenden Sie zum Verschieben vorhandener Ressourcen in eine andere Ressourcengruppe oder ein anderes Abonnement die Methode ResourceManagementClient.resources.begin_move_resources. Im folgenden Beispiel wird veranschaulicht, wie mehrere Ressourcen in eine neue Ressourcengruppe verschoben werden.

import os
from azure.identity import AzureCliCredential
from azure.mgmt.resource import ResourceManagementClient

credential = AzureCliCredential()
subscription_id = os.environ["AZURE_SUBSCRIPTION_ID"]

resource_client = ResourceManagementClient(credential, subscription_id)

source_name = "sourceRG"
destination_name = "destinationRG"
resources_to_move = ["app1", "app2"]

destination_resource_group = resource_client.resource_groups.get(destination_name)

resources = [
  resource for resource in resource_client.resources.list_by_resource_group(source_name)
  if resource.name in resources_to_move
]

resource_ids = [resource.id for resource in resources]

resource_client.resources.begin_move_resources(
  source_name,
  {
  "resources": resource_ids,
  "target_resource_group": destination_resource_group.id
  }
)

REST-API

Überprüfen

Der Vorgang zum Überprüfen der Verschiebung ermöglicht Ihnen, Ihr Verschiebungsszenario zu testen, ohne tatsächlich Ressourcen zu verschieben. Verwenden Sie diesen Vorgang, um zu überprüfen, ob die Verschiebung erfolgreich ist. Die Überprüfung wird automatisch aufgerufen, wenn Sie eine Verschiebeanforderung senden. Verwenden Sie diesen Vorgang nur, wenn Sie die Ergebnisse vorab bestimmen müssen. Um diesen Vorgang ausführen zu können, benötigen Sie Folgendes:

  • Name der Quellressourcengruppe
  • Ressourcen-ID der Zielressourcengruppe
  • Ressourcen-ID der einzelnen zu verschiebenden Ressourcen
  • Das Zugriffstoken für Ihr Konto

Senden Sie die folgende Anforderung:

POST https://management.azure.com/subscriptions/<subscription-id>/resourceGroups/<source-group>/validateMoveResources?api-version=2019-05-10
Authorization: Bearer <access-token>
Content-type: application/json

Mit dem Anforderungstext:

{
 "resources": ["<resource-id-1>", "<resource-id-2>"],
 "targetResourceGroup": "/subscriptions/<subscription-id>/resourceGroups/<target-group>"
}

Wenn die Anforderung ordnungsgemäß formatiert ist, gibt der Vorgang Folgendes zurück:

Response Code: 202
cache-control: no-cache
pragma: no-cache
expires: -1
location: https://management.azure.com/subscriptions/<subscription-id>/operationresults/<operation-id>?api-version=2018-02-01
retry-after: 15
...

Die Statuscode 202 gibt an, dass die Überprüfungsanforderung akzeptiert wurde, jedoch noch nicht ermittelt wurde, ob der Verschiebungsvorgang erfolgreich verläuft. Die Wert location enthält eine URL, über die Sie den Status des lang andauernden Vorgangs überprüfen können.

Um den Status zu überprüfen, senden Sie die folgende Anforderung:

GET <location-url>
Authorization: Bearer <access-token>

Während der Vorgang ausgeführt wird, wird weiterhin der Statuscode 202 angezeigt. Warten Sie die Anzahl von Sekunden, die im Wert retry-after angegeben ist, bevor Sie es erneut versuchen. Wenn der Verschiebungsvorgang erfolgreich überprüft wurde, erhalten Sie den Statuscode 204. Wenn bei der Verschiebungsüberprüfung ein Fehler auftritt, erhalten Sie eine Fehlermeldung, z.B.:

{"error":{"code":"ResourceMoveProviderValidationFailed","message":"<message>"...}}

Move

Verwenden Sie zum Verschieben vorhandener Ressourcen in eine andere Ressourcengruppe oder ein anderes Abonnement den Vorgang zum Verschieben von Ressourcen.

POST https://management.azure.com/subscriptions/{source-subscription-id}/resourcegroups/{source-resource-group-name}/moveResources?api-version={api-version}

Geben Sie im Anforderungstext die Zielgruppe und die zu verschiebenden Ressourcen an.

{
 "resources": ["<resource-id-1>", "<resource-id-2>"],
 "targetResourceGroup": "/subscriptions/<subscription-id>/resourceGroups/<target-group>"
}

Häufig gestellte Fragen

Mein Ressourcenverschiebevorgang, der normalerweise ein paar Minuten dauert, läuft schon seit fast einer Stunde. Stimmt da etwas nicht?

Das Verschieben einer Ressource ist ein komplexer Vorgang, der in verschiedenen Phasen erfolgt. Es kann mehr als nur den Ressourcenanbieter der Ressource umfassen, die Sie verschieben möchten. Aufgrund der Abhängigkeiten zwischen Ressourcenanbietern stellt Azure Resource Manager vier Stunden bereit, um den Vorgang abzuschließen. Dieser Zeitraum gibt Ressourcenanbietern die Möglichkeit, sich von vorübergehenden Problemen wiederherzustellen. Wenn Ihre Verschiebeanforderung innerhalb des Zeitraums von vier Stunden liegt, wird weiterhin versucht, den Vorgang abzuschließen. Dies kann auch erfolgreich sein. Die Quell- und Zielressourcengruppen sind während dieses Zeitraums gesperrt, um Konsistenzprobleme zu vermeiden.

Warum ist meine Ressourcengruppe während der Ressourcenverschiebung für vier Stunden gesperrt?

Eine Verschiebeanforderung darf maximal vier Stunden dauern. Um Änderungen an den zu verschiebenden Ressourcen zu verhindern, werden sowohl die Quell- als auch die Zielressourcengruppe während der Ressourcenverschiebung gesperrt.

Es gibt zwei Phasen bei einer Verschiebeanforderung. In der ersten Phase wird die Ressource verschoben. In der zweiten Phase werden Benachrichtigungen an andere Ressourcenanbieter gesendet, die von der Ressource abhängen, die verschoben wird. Eine Ressourcengruppe kann für das gesamte Zeitfenster von vier Stunden gesperrt werden, wenn ein Ressourcenanbieter in einer der beiden Phasen fehlschlägt. Während des gewährten Zeitraums versucht Resource Manager, den fehlgeschlagenen Schritt zu wiederholen.

Wenn eine Ressource nicht innerhalb des Zeitfensters von vier Stunden verschoben werden kann, entsperrt Resource Manager beide Ressourcengruppen. Ressourcen, die erfolgreich verschoben wurden, befinden sich in der Zielressourcengruppe. Ressourcen, die nicht verschoben werden konnten, verbleiben in der Quellressourcengruppe.

Welche Auswirkungen hat es, wenn die Quell- und Zielressourcengruppen während der Ressourcenverschiebung gesperrt werden?

Die Sperre verhindert, dass Sie eine der Ressourcengruppen löschen. Außerdem verhindert die Sperre, dass Sie in den Ressourcengruppen neue Ressource erstellen, Ressourcen löschen oder die Eigenschaften von Ressourcen ändern (z. B. die VM-Größe).

In der folgenden Abbildung wird eine Fehlermeldung des Azure-Portals angezeigt, wenn ein Benutzer versucht, eine Ressourcengruppe zu löschen, die Bestandteil einer laufenden Verschiebung ist.

Screenshot: Im Azure-Portal wird eine Fehlermeldung angezeigt, wenn versucht wird, eine am laufenden Verschiebevorgang beteiligte Ressourcengruppe zu löschen.

In der folgenden Abbildung gehört die VM-Ressource zu einer Ressourcengruppe („TestB“), in der derzeit eine Verschiebung erfolgt. Wenn Benutzende versuchen, eine Eigenschaft der VM zu ändern (z. B. ihre Größe), wird im Azure-Portal eine Fehlermeldung ausgegeben. Dies Ursache hierfür ist, dass die Ressourcengruppe während der Verschiebung gesperrt ist, um Änderungen an ihren Ressourcen zu verhindern.

Screenshot einer Fehlermeldung im Azure-Portal, wenn Benutzende versuchen, eine Eigenschaft (VM-Größe) der VM zu ändern

Darüber hinaus können während einer Ressourcenverschiebung weder für die Quell- noch für die Zielressourcengruppe gleichzeitig weitere Verschiebungen durchgeführt werden. Wenn z. B. Ressourcen aus der Ressourcengruppe A in die Ressourcengruppe B verschoben werden, können weder für Gruppe A noch für Gruppe B andere Verschiebungen durchgeführt werden (z. B. zum Verschieben von Ressourcen in oder aus Ressourcengruppe C). Mit dieser Einschränkung wird sichergestellt, dass Ressourcengruppen während des Verschiebevorgangs nicht durch mehrere widersprüchliche Vorgänge gesperrt werden.

Was bedeutet der Fehlercode „MissingMoveDependentResources“?

Beim Verschieben einer Ressource müssen deren abhängige Ressourcen in der Zielressourcengruppe oder im Zielabonnement vorhanden sein oder in die Verschiebeanforderung eingeschlossen werden. Sie erhalten den Fehlercode „MissingMoveDependentResources“, wenn eine abhängige Ressource diese Anforderung nicht erfüllt. Die Fehlermeldung enthält Details über die abhängige Ressource, die in die Verschiebeanforderung eingeschlossen werden muss.

Beispielsweise könnte das Verschieben eines virtuellen Computers erfordern, dass sieben Ressourcentypen mit drei verschiedenen Ressourcenanbietern verschoben werden. Diese Ressourcenanbieter und -typen sind:

  • Microsoft.Compute

    • virtualMachines
    • disks
  • Microsoft.Network

    • networkInterfaces
    • publicIPAddresses
    • networkSecurityGroups
    • virtualNetworks
  • Microsoft.Storage

    • storageAccounts

Ein weiteres gängiges Beispiel beinhaltet das Verschieben eines virtuellen Netzwerks. Sie müssen möglicherweise mehrere weitere Ressourcen verschieben, die diesem virtuellen Netzwerk zugeordnet sind. Die Verschiebeanforderung kann es erfordern, dass öffentliche IP-Adressen, Routingtabellen, virtuelle Netzwerkgateways, Netzwerksicherheitsgruppen und anderes verschoben werden. Im Allgemeinen muss sich ein virtuelles Netzwerkgateway immer in derselben Ressourcengruppe befinden wie das zugehörige virtuelle Netzwerk. Sie können nicht separat verschoben werden.

Was bedeutet der Fehlercode „RequestDisallowedByPolicy“?

Resource Manager validiert Ihre Verschiebungsanforderung, bevor versucht wird, sie auszuführen. Diese Validierung umfasst das Überprüfen von Richtlinien, die für die an der verschobenen Ressourcen definiert sind. Wenn Sie z. B. versuchen, einen Schlüsseltresor zu verschieben, Ihre Organisation jedoch über eine Richtlinie verfügt, um die Erstellung eines Schlüsseltresors in der Zielressourcengruppe zu verweigern, schlägt die Validierung fehl, und die Verschiebung wird blockiert. Der zurückgegebene Fehlercode ist RequestDisallowedByPolicy.

Weitere Informationen zu Richtlinien finden Sie unter Was ist Azure Policy?.

Warum kann ich einige Ressourcen in Azure nicht verschieben?

Derzeit unterstützen nicht alle Ressourcen in Azure das Verschieben. Eine Liste der Ressourcen, die das Verschieben unterstützen, finden Sie unter Unterstützung des Verschiebevorgangs für Ressourcen.

Wie viele Ressourcen kann ich in einem einzigen Vorgang verschieben?

Unterteilen Sie große Verschiebevorgänge nach Möglichkeit in separate Verschiebevorgänge. Resource Manager gibt sofort einen Fehler aus, wenn ein einziger Vorgang mehr als 800 Ressourcen umfasst. Beim Verschieben von weniger als 800 Ressourcen kann jedoch ebenfalls ein Fehler durch ein Timeout auftreten.

Was bedeutet der Fehler, dass eine Ressource nicht erfolgreich ist?

Wenn Sie eine Fehlermeldung erhalten, die besagt, dass eine Ressource nicht verschoben werden kann, da sie sich nicht in einem erfolgreichen Zustand befindet, blockiert möglicherweise eine abhängige Ressource die Verschiebung. In der Regel lautet der Fehlercode MoveCannotProceedWithResourcesNotInSucceededState.

Wenn die Quell- oder Zielgruppenressource ein virtuelles Netzwerk enthält, werden während des Verschiebens die Zustände aller abhängigen Ressourcen des virtuellen Netzwerks überprüft. Die Überprüfung umfasst direkt und indirekt vom virtuellen Netzwerk abhängige Ressourcen. Wenn eine dieser Ressourcen den Zustand „Ausgefallen“ aufweist, wird die Verschiebung blockiert. Wenn beispielsweise ein virtueller Computer, der das virtuelle Netzwerk nutzt, ausgefallen ist, wird das Verschieben blockiert. Das Verschieben wird selbst dann blockiert, wenn der virtuelle Computer nicht zu den zu verschiebenden Ressourcen gehört und sich nicht in einer der Ressourcengruppen des Verschiebevorgangs befindet.

Wenn Sie diesen Fehler erhalten, haben Sie zwei Möglichkeiten. Verschieben Sie entweder Ihre Ressourcen in eine Ressourcengruppe ohne virtuelles Netzwerk, oder kontaktieren Sie den Support.

Kann ich eine Ressourcengruppe in ein anderes Abonnement verschieben?

Nein, Sie können eine Ressourcengruppe nicht in ein neues Abonnement verschieben. Aber Sie können alle Ressourcen der Ressourcengruppe in eine Ressourcengruppe eines anderen Abonnements verschieben. Einstellungen wie Tags, Rollenzuweisungen und Richtlinien werden nicht automatisch von der ursprünglichen Ressourcengruppe auf die Zielressourcengruppe übertragen. Diese Einstellungen müssen Sie erneut auf die neue Ressourcengruppe anwenden. Weitere Informationen finden Sie unter Verschieben von Ressourcen in eine neue Ressourcengruppe oder ein neues Abonnement.

Nächste Schritte

Eine Liste der Ressourcen, die das Verschieben unterstützen, finden Sie unter Unterstützung des Verschiebevorgangs für Ressourcen.