Move Azure Event Grid custom topics to another region

You might want to move your resources to another region for a number of reasons. For example, to take advantage of a new Azure region, to meet internal policy and governance requirements, or in response to capacity planning requirements.

Here are the high-level steps covered in this article:

  • Export the custom topic resource to an Azure Resource Manager template.

    Important

    Only the custom topic is exported to the template. Any subscriptions for the topic aren't exported.

  • Use the template to deploy the custom topic to the target region.

  • Create subscriptions manually in the target region. When you exported the custom topic to a template in the current region, only the topic is exported. Subscriptions aren't included in the template, so create them manually after the custom topic is created in the target region.

  • Verify the deployment. Verify that the custom topic is created in the target region.

  • To complete the move, delete custom topic from the source region.

Prerequisites

Prepare

To get started, export a Resource Manager template for the custom topic.

  1. Sign in to the Azure portal.

  2. In the search bar, type Event Grid topics, and select Event Grid Topics from the results list.

    Search for and select Event Grid topics

  3. Select the topic that you want to export to a Resource Manager template.

    Select the custom topic

  4. On the Event Grid Topic page, select Export Template under Settings on the left menu, and then select Download on the toolbar.

    Export template -> Download

    Important

    Only the topic is exported to the template. Subscriptions for the topic aren't exported. So, you need to create subscriptions for the topic after you move the topic to the target region.

  5. Locate the .zip file you downloaded from the portal, and unzip that file to a folder of your choice. This zip file contains template and parameters JSON files.

  6. Open the template.json in an editor of your choice.

  7. Update location for the topic resource to the target region or location. To obtain location codes, see Azure locations. The code for a region is the region name with no spaces, for example, West US is equal to westus.

    "type": "Microsoft.EventGrid/topics",
    "apiVersion": "2020-06-01",
    "name": "[parameters('topics_mytopic0130_name')]",
    "location": "westus"
    
  8. Save the template.

Recreate

Deploy the template to create a custom topic in the target region.

  1. In the Azure portal, select Create a resource.
  2. In Search the Marketplace, type template deployment, and then press ENTER.
  3. Select Template deployment.
  4. Select Create.
  5. Select Build your own template in the editor.
  6. Select Load file, and then follow the instructions to load the template.json file that you downloaded in the last section.
  7. Select Save to save the template.
  8. On the Custom deployment page, follow these steps:
    1. Select an Azure subscription.

    2. Select an existing resource group in the target region or create one.

    3. For Region, select the target region. If you selected an existing resource group, this setting is read-only.

    4. For the topic name, enter a new name for the topic.

    5. Select Review + create at the bottom of the page.

      Custom deployment

    6. On the Review + create page, review settings, and select Create.

Verify

  1. After the deployment succeeds, select Go to resource.

    Go to resource

  2. Confirm that you see the Event Grid Topic page for the custom topic.

  3. Follow steps in the Route custom events to a web endpoint to send events to the topic. Verify that the webhook event handler is invoked.

Discard or clean up

To complete the move, delete the custom topic in the source region.

If you want to start over, delete the topic in the target region, and repeat steps in the Prepare and Recreate sections of this article.

To delete a custom topic by using the Azure portal:

  1. In the search window at the top of Azure portal, type Event Grid Topics, and select Event Grid Topics from search results.
  2. Select the topic to delete, and select Delete from the toolbar.
  3. On the confirmation page, enter the name of the resource group, and select Delete.

To delete the resource group that contains the custom topic by using the Azure portal:

  1. In the search window at the top of Azure portal, type Resource groups, and select Resource groups from search results.
  2. Select the resource group to delete, and select Delete from the toolbar.
  3. On the confirmation page, enter the name of the resource group, and select Delete.

Next steps

You learned how to move an Event Grid custom topic from one region to another region. See the following articles for moving system topics, domains, and partner namespaces across regions.

To learn more about moving resources between regions and disaster recovery in Azure, see the following article: Move resources to a new resource group or subscription.