Поделиться через


Перемещение ресурсов Azure в новую группу ресурсов или подписку

В этой статье объясняется, как перемещать ресурсы Azure между группами ресурсов, независимо от того, находятся ли они в одной подписке или в разных подписках. Если перемещение включает разные подписки, обе подписки должны быть частью одного клиента Идентификатора Microsoft Entra. Вы можете выполнить перемещение с помощью таких средств, как портал Azure, Azure PowerShell, Azure CLI, REST API или Python.

Во время операции перемещения исходные и целевые группы ресурсов блокируются. Это означает, что вы не можете создавать, удалять или обновлять ресурсы в этих группах ресурсов во время перемещения. Однако существующие ресурсы остаются полностью операционными. Например, если вы перемещаете виртуальную машину из одной группы ресурсов в другую, виртуальная машина не может быть удалена, а его свойства (например, размер виртуальной машины) нельзя изменить во время перемещения. Несмотря на это, виртуальная машина продолжает работать в обычном режиме, и службы, использующие ее, не будут испытывать никаких дополнительных простоев. Блокировка может длиться до четырех часов, но большинство ходов завершается быстрее, и блокировка удаляется соответствующим образом.

В запросе перемещения должны быть указаны только ресурсы верхнего уровня (родителя). Дочерние ресурсы автоматически перемещаются вместе со своим родительским, но не могут быть перемещены независимо. Например, родительский ресурс, как Microsoft.Compute/virtualMachines можно переместить, и его дочерний ресурс, например Microsoft.Compute/virtualMachines/extensions, будет перемещен вместе с ним. Однако дочерний ресурс нельзя переместить самостоятельно.

При перемещении ресурса сохраняются зависимости с дочерними ресурсами, зависимости с другими ресурсами могут прерываться и требовать перенастройки. Перемещение ресурса изменяет только связанную группу ресурсов, она не изменяет физический регион ресурса.

Примечание.

Ресурсы Azure нельзя переместить, если блокировка только для чтения существует в исходной или целевой группе ресурсов или подписке.

Изменение идентификатора ресурса

При перемещении ресурса изменяется его идентификатор. Стандартный формат для идентификатора ресурса — /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}. При перемещении ресурса в новую группу ресурсов или подписку вы изменяете одно или несколько значений в этом пути.

Если вы используете идентификатор ресурса в любом месте, необходимо изменить это значение. Например, если на портале есть пользовательская панель мониторинга , ссылающаяся на идентификатор ресурса, необходимо обновить это значение. Найдите скрипты или шаблоны, которые необходимо обновить для нового идентификатора ресурса.

Рекомендации перед перемещением ресурсов

Вот некоторые важные особенности, которые следует учитывать перед перемещением ресурса. Проверив эти условия, можно избежать ошибок.

  1. Исходная и целевая подписки должны быть активными. Если у вас возникла проблема при включении учетной записи, которая была отключена, создайте запрос на поддержку Azure. Выберите тип проблемы Управление подпиской.

  2. Исходная и целевая подписка должны существовать в пределах одного клиента Microsoft Entra. Используя Azure PowerShell или командную строку Azure, можно убедиться, что обе подписки имеют один и тот же идентификатор клиента.

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

    Если идентификаторы клиентов исходных и целевых подписок не совпадают, используйте следующие методы для выверки идентификаторов клиентов:

  3. Если вы хотите перенести ресурсы партнеру поставщика облачных решений или из него, см. статью Перенос подписок Azure между подписчиками и CSP.

  4. Ресурсы, которые требуется переместить, должны поддерживать операцию перемещения. Список ресурсов, поддерживающих перемещение, см. в статье Поддержка операций перемещения для ресурсов.

  5. При перемещении ресурсов некоторые службы имеют определенные ограничения или требования. Если вы перемещаете одну из следующих служб, то перед перемещением сверьтесь с этим руководством.

  6. Подписка назначения должна быть зарегистрирована для перемещаемого поставщика ресурсов. В противном случае отображается сообщение о том, что подписка не зарегистрирована для типа ресурса. Эта ошибка может возникнуть при перемещении ресурса в новую подписку, которая никогда не использовалась с этим типом ресурса.

    Чтобы получить состояние регистрации:

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

    Чтобы зарегистрировать поставщик ресурсов сделайте следующее:

    az provider register --namespace Microsoft.Batch
    
  7. Прежде чем перемещать ресурсы, проверьте квоты подписки, в которую вы перемещаете ресурсы. Если перемещение ресурсов означает, что подписка превышает свои ограничения, необходимо проверить, можно ли запросить увеличение квоты. Полный список ограничений и способы запросить увеличение квоты см. в статье Подписка Azure, границы, квоты и ограничения службы.

  8. Учетная запись, используемая для перемещения ресурсов, должна предоставлять по крайней мере следующие разрешения:

    • Microsoft.Resources/subscriptions/resourceGroups/moveResources/action для исходной группы ресурсов;
    • Microsoft.Resources/subscriptions/resourceGroups/write для целевой группы ресурсов.
  9. При перемещении ресурса, для которого роль Azure назначена непосредственно самому ресурсу (или дочернему ресурсу), назначение ролей не перемещается и теряется. После перемещения необходимо повторно создать назначение ролей. Со временем потерянное назначение ролей удаляется автоматически, однако мы рекомендуем удалить назначение ролей перед перемещением.

    Сведения об управлении назначениями ролей см. в разделах Вывод списка назначений ролей Azure и Назначение ролей Azure.

  10. Для перемещения между подписками ресурс и его зависимые ресурсы должны находиться в одной группе ресурсов, а также они должны перемещаться вместе. Например, виртуальная машина с управляемыми дисками потребует перемещения вместе с управляемыми дисками и другими зависимыми ресурсами.

    При перемещении ресурса в новую подписку, проверьте, имеет ли ресурс зависимые ресурсы, и находятся ли они в той же группе ресурсов. Если ресурсы находятся в разных группах ресурсов, проверьте, можно ли объединить эти ресурсы в одну группу ресурсов. Если можно, перенесите все эти ресурсы в одну группу ресурсов, используя операцию перемещения в группах ресурсов.

    Дополнительные сведения см. в разделе Сценарий перемещения между подписками.

Scenario for move across subscriptions (Сценарий перемещения между подписками)

Перемещение ресурсов из одной подписки в другую включает три этапа.

Схема, демонстрирующая трехэтапный процесс перемещения ресурсов между подписками.

Для наглядности мы используем только один зависимый ресурс.

  • Шаг 1. Если зависимые ресурсы распределены по разным группам ресурсов, сначала переместите их в одну группу ресурсов.
  • Шаг 2. Совместно переместите ресурс и зависимые ресурсы из исходной подписки в целевую.
  • Step 3: При необходимости перераспределите зависимые ресурсы по разным группам ресурсов в целевой подписке.

Перемещение ресурсов

Использование портала

Чтобы переместить ресурсы, выберите группу ресурсов, которая содержит эти ресурсы.

Выбор ресурсов, которые требуется переместить. Чтобы переместить все ресурсы, установите флажок в верхней части списка. Или выберите ресурсы по отдельности.

Снимок экрана: портал Azure с выбором ресурсов для перемещения.

Нажмите кнопку Переместить.

Снимок экрана: портал Azure с кнопкой

Эта кнопка предоставляет выбор из трех вариантов:

Укажите, куда будут перемещены ресурсы: в новую группу ресурсов или новую подписку.

Исходная группа ресурсов устанавливается автоматически. Выберите целевую группу ресурсов. Если вы перемещаете ресурсы в новую подписку, также укажите подписку. Выберите Далее.

Снимок экрана: портал Azure, где пользователь указывает целевую группу ресурсов для операции перемещения.

Портал проверит возможность перемещения ресурсов. Дождитесь завершения проверки.

Снимок экрана: портал Azure с процессом проверки для операции перемещения.

После успешного завершения проверки нажмите кнопку Далее.

Подтвердите обновление инструментов и сценариев для этих ресурсов. Чтобы начать перемещение ресурсов, выберите Переместить.

Снимок экрана: портал Azure, где пользователь признает необходимость обновления средств и скриптов перед началом операции перемещения.

После ее завершения перемещения отобразится уведомление о результате.

Снимок экрана: портал Azure отображение уведомления с результатами операции перемещения.

Использование Azure CLI

Проверить

Чтобы протестировать сценарий перемещения без фактического перемещения ресурсов, используйте команду az resource invoke-action. Используйте эту команду только в том случае, если необходимо предварительно определить результаты. Для запуска этой операции вам необходимо:

  • Идентификатор ресурса исходной группы ресурсов
  • Идентификатор ресурса целевой группы ресурсов
  • Идентификатор каждого перемещаемого ресурса

В тексте запроса используйте \" для экранирования двойных кавычек.

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}\" }" 

Если проверка пройдет успешно, вы увидите следующее:

{} Finished .. 

Если проверка завершится неудачно, отобразится сообщение об ошибке с описанием причин, по которым переместить ресурсы невозможно.

Передвинуть

Чтобы переместить существующие ресурсы в другую группу или подписку, используйте команду az resource move. В параметре --ids укажите перемещаемый список идентификаторов ресурсов с разделителями-пробелами.

В следующем примере показано, как переместить несколько ресурсов в новую группу ресурсов. Он работает при использовании Azure CLI в терминале Bash .

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

В следующем примере показано, как выполнять те же команды в консоли PowerShell .

$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

Для перемещения в новую подписку нужно указать параметр --destination-subscription-id.

Использование Azure PowerShell

Проверить

Чтобы протестировать сценарий перемещения без фактического перемещения ресурсов, используйте команду Invoke-AzResourceAction. Используйте эту команду только в том случае, если необходимо предварительно определить результаты.

$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
  }

Если проверка выполнена успешно, выходные данные не отображаются. Однако если проверка завершается ошибкой, появится сообщение об ошибке, объясняя причины, по которым ресурсы не могут быть перемещены.

Передвинуть

Чтобы переместить существующие ресурсы в другую группу ресурсов или подписку, используйте команду Move-AzResource. В следующем примере показано, как переместить несколько ресурсов в новую группу ресурсов.

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

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

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

Чтобы переместить ресурс в новую подписку, добавьте значение параметра DestinationSubscriptionId.

Использование Python

Проверить

Чтобы протестировать сценарий перемещения без фактического перемещения ресурсов, используйте метод ResourceManagementClient.resources.begin_validate_move_resources . Используйте этот метод только в том случае, если необходимо заранее определить результаты.

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))

Если проверка выполнена успешно, выходные данные не отображаются. Однако если проверка завершается ошибкой, появится сообщение об ошибке, объясняя причины, по которым ресурсы не могут быть перемещены.

Передвинуть

Чтобы переместить существующие ресурсы в другую группу ресурсов или подписку, используйте метод ResourceManagementClient.resources.begin_move_resources . В следующем примере показано, как переместить несколько ресурсов в новую группу ресурсов.

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

Проверить

Операция проверки перемещения позволяет проверить сценарий перемещения без фактического перемещения ресурсов. Используйте эту операцию для проверки успешности перемещения. Проверка вызывается автоматически при отправке запроса на перемещение. Используйте эту операцию только в том случае, если необходимо предварительно определить результаты. Для запуска этой операции вам необходимо:

  • Имя исходной группы ресурсов
  • Идентификатор ресурса целевой группы ресурсов
  • Идентификатор каждого перемещаемого ресурса
  • Маркер доступа для вашей учетной записи

Отправьте следующий запрос:

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

С текстом запроса:

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

Если запрос имеет правильный формат, операция возвращает следующее:

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
...

Код состояния 202 указывает, что запрос на проверку был принят, но еще не определено, завершится ли операция перемещения успешно. Значение location содержит URL-адрес, который используется для проверки состояния продолжительной операции.

Чтобы проверить состояние, отправьте следующий запрос:

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

Пока операция все еще выполняется, вы по-прежнему получаете код состояния 202. Подождите в течение времени, указанного в значении retry-after, прежде чем повторять попытку. Если проверка операции перемещения завершена успешно, вы получите код состояния 204. Если проверка перемещения закончилась ошибкой, вы получите сообщение об ошибке, например:

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

Передвинуть

Чтобы переместить существующие ресурсы в другую группу ресурсов или подписку, используйте операцию Перемещение ресурсов.

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

В тексте запроса укажите целевую группу ресурсов и ресурсы для перемещения.

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

Часто задаваемые вопросы

Моя операция перемещения ресурсов, которая обычно занимает несколько минут, выполняется почти час. Что не так?

Перемещение ресурса — это сложная операция с разными этапами. Она может затрагивать не только поставщика ресурсов того ресурса, который вы пытаетесь переместить. Из-за зависимостей между поставщиками ресурсов Azure Resource Manager выделяет до 4 часов для завершения операции. Этот период времени дает поставщикам ресурсов возможность восстановиться после возникновения временных проблем. Если ожидание обработки вашего запроса на перемещение находится в пределах этого 4-часового периода, операция продолжает осуществлять попытки завершиться и, возможно, будет выполнена. В течение этого времени исходная и целевая группы ресурсов блокируются во избежание возникновения проблем с согласованностью.

Почему группа ресурсов блокируется на четыре часа во время перемещения ресурса?

Для выполнения запроса на перемещение выделяется не более четырех часов. Чтобы не допустить изменение перемещаемых ресурсов, во время перемещения ресурса исходная и целевая группы ресурсов блокируются.

Выполнение запроса на перемещение состоит из двух этапов. На первом этапе перемещается ресурс. На втором этапе отправляются уведомления другим поставщикам ресурсов, которые зависят от перемещаемого ресурса. Группа ресурсов может быть заблокирована на все четыре часа, если поставщику ресурсов не удается завершить какой-либо этап. В течение выделенного времени Resource Manager попытается завершить этап, на котором возникла ошибка.

Если ресурс не удается переместить в течение четырех часов, Resource Manager разблокирует обе группы ресурсов. Успешно перемещенные ресурсы будут находиться в целевой группе ресурсов. Ресурсы, которые не удалось переместить, остаются в исходной группе ресурсов.

Каковы последствия блокировки исходных и целевых групп ресурсов при перемещении ресурса?

Блокировка предотвращает удаление любой группы ресурсов. Во-вторых, в каждой группе ресурсов блокировка предотвращает создание нового ресурса, удаление ресурса или обновление свойств ресурса (например, изменение размера виртуальной машины).

На следующем рисунке показано сообщение об ошибке на портале Azure, возникающей, когда пользователь пытается удалить группу ресурсов, которая участвует в текущем перемещении.

Снимок экрана: портал Azure с сообщением об ошибке при попытке удалить группу ресурсов, связанную с текущей операцией перемещения.

На приведенном ниже рисунке ресурс виртуальной машины принадлежит группе ресурсов (TestB), которая в настоящее время проходит операцию перемещения. Когда пользователь пытается обновить свойство виртуальной машины, например его размер, портал Azure возвращает сообщение об ошибке. Это происходит, так как группа ресурсов заблокирована во время перемещения, предотвращая любые изменения в своих ресурсах.

Снимок экрана: портал Azure с сообщением об ошибке при попытке пользователя обновить свойство (размер виртуальной машины) виртуальной машины.

Кроме того, во время перемещения ресурсов ни источник, ни целевая группа ресурсов не могут одновременно участвовать в других операциях перемещения. Например, если ресурсы перемещаются из группы ресурсов A в группу ресурсов B, ни группа А, ни группа B не могут быть вовлечены в другую операцию перемещения, например перемещение ресурсов в группу ресурсов C или из нее одновременно. Это ограничение гарантирует, что группы ресурсов не блокировались несколькими конфликтующими операциями во время процесса перемещения.

Что означает код ошибки "MissingMoveDependentResources"?

При перемещении ресурса его зависимые ресурсы должны существовать в целевой группе ресурсов или подписке или включаться в запрос перемещения. Если зависимый ресурс не отвечает этому требованию, выводится код ошибки MissingMoveDependentResources. Сообщение об ошибке содержит сведения о зависимом ресурсе, который необходимо добавить в запрос на перемещение.

Например, перемещение виртуальной машины может потребовать перемещения семи типов ресурсов с тремя разными поставщиками ресурсов. К этими поставщикам ресурсов относятся:

  • Microsoft.Compute;

    • virtualMachines
    • disks
  • Microsoft.Network.

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

    • storageAccounts

Другой распространенный пример затрагивает перемещение виртуальной сети. Может потребоваться переместить несколько других ресурсов, связанных с этой виртуальной сетью. Для выполнения запроса на перемещение может потребоваться переместить общедоступные IP-адреса, таблицы маршрутизации, шлюзы виртуальной сети, группы безопасности сети и т. д. Как правило, шлюз виртуальной сети всегда должен находиться в той же группе ресурсов, что и ее виртуальная сеть, они не могут быть перемещены отдельно.

Что означает код ошибки "RequestDisallowedByPolicy"?

Resource Manager проверяет запрос на перемещение перед попыткой перемещения. Эта проверка включает в себя проверку политик, определенных для ресурсов, участвующих в перемещении. Например, если вы пытаетесь переместить хранилище ключей, но в вашей организации есть политика, запрещающая создание хранилища ключей в целевой группе ресурсов, то проверка завершится сбоем и перемещение будет заблокировано. Возвращаемый код ошибки — RequestDisallowedByPolicy.

Дополнительные сведения о политиках см. в статье Что такое служба "Политика Azure"?

Почему не удается переместить некоторые ресурсы в Azure?

Сейчас не все ресурсы в Azure поддерживают перемещение. Список ресурсов, поддерживающих перемещение, см. в статье Поддержка операций перемещения для ресурсов.

Сколько ресурсов можно переместить за одну операцию?

Если это возможно, разделите большие перемещения на несколько операций перемещения. При попытке перемещения более чем 800 ресурсов за одну операцию Resource Manager немедленно возвращает ошибку. Однако перемещение менее чем 800 ресурсов может также завершиться со сбоем из-за превышения времени ожидания.

Что означает ошибка, в сообщении о которой указано, что ресурс не находится в состоянии "Успешно"?

При получении сообщения об ошибке, указывающего на то, что ресурс нельзя переместить, поскольку он не находится в состоянии "успешно", это может означать, что он фактически является зависимым ресурсом, что приводит к блокированию перемещения. Как правило, код ошибки в таком случае — MoveCannotProceedWithResourcesNotInSucceededState.

Если исходная или целевая группа ресурсов содержит виртуальную сеть, во время перемещения будут проверяться состояния всех зависимых ресурсов для виртуальной сети. Эта проверка включает ресурсы прямо и косвенно, в зависимости от виртуальной сети. Если какие-либо из этих ресурсов находятся в состоянии сбоя, перемещение блокируется. Например, если виртуальная машина, использующая виртуальную сеть, завершилась сбоем, перемещение блокируется. Перемещение блокируется, даже если виртуальная машина не является одним из перемещаемых ресурсов и не находится в одной из групп ресурсов для перемещения.

При возникновении этой ошибки у вас есть два варианта. Либо переместите ресурсы в группу ресурсов без виртуальной сети, либо обратитесь в службу поддержки.

Можно ли переместить группу ресурсов в другую подписку?

Нет, вы не можете переместить группу ресурсов в новую подписку. Но вы можете переместить все ресурсы в группу ресурсов в другую подписку. Такие параметры, как теги, назначения ролей и политики, не передаются из исходной группы ресурсов в целевую группу ресурсов. Эти параметры необходимо повторно применить к новой группе ресурсов. Дополнительные сведения см. в статье Перемещение ресурсов в новую группу ресурсов или подписку.

Следующие шаги

Список ресурсов, поддерживающих перемещение, см. в статье Поддержка операций перемещения для ресурсов.