Azure Load Balancer를 다른 Azure 지역으로 이동
내부 또는 외부 부하 분산 장치를 한 지역에서 다른 지역으로 이동하려는 다양한 시나리오가 있습니다. 예를 들어 테스트를 위해 동일한 구성으로 다른 부하 분산 장치를 만들 수 있습니다. 재해 복구 계획의 일환으로 부하 분산 장치를 다른 지역으로 이동할 수도 있습니다.
리터럴 측면에서 Azure 부하 분산 장치를 한 지역에서 다른 지역으로 이동할 수 없습니다. 그러나 Azure Resource Manager 템플릿을 사용하여 부하 분산 장치의 기존 구성 및 공용 IP 주소를 내보낼 수 있습니다. 그런 다음, 부하 분산 장치와 공용 IP를 템플릿으로 내보내고, 대상 지역과 일치하도록 매개 변수를 수정한 다음, 템플릿을 새 지역에 배포하여 리소스를 다른 지역에 스테이징할 수 있습니다. Resource Manager 및 템플릿에 대한 자세한 내용은 템플릿으로 리소스 그룹 내보내기를 참조하세요.
이 문서에서는 Azure Portal 또는 Azure PowerShell을 사용하여 외부 또는 내부 부하 분산 장치를 한 Azure 지역에서 다른 지역으로 이동하는 방법을 알아봅니다. 원하는 방법 및 이동하려는 부하 분산 장치 유형과 일치하는 탭을 선택합니다.
이 절차를 사용하여 Azure Portal 또는 Azure PowerShell을 사용하여 외부 부하 분산 장치를 다른 지역으로 이동합니다.
이동하려는 Azure 지역에 Azure 외부 부하 분산 장치가 있는지 확인합니다.
Azure 외부 부하 분산 장치는 지역 간에 이동할 수 없습니다. 새 부하 분산 장치를 대상 지역의 리소스에 연결해야 합니다.
외부 부하 분산 장치 구성을 내보내고 템플릿을 배포하여 다른 지역에 외부 부하 분산 장치를 만들려면 네트워크 기여자 역할 이상이 필요합니다.
현재 사용하고 있는 모든 리소스와 원본 네트워킹 레이아웃을 식별합니다. 이 레이아웃에는 부하 분산 장치, 네트워크 보안 그룹, 공용 IP 및 가상 네트워크를 포함하되 국한되지 않습니다.
Azure 구독에서 대상 지역에 외부 부하 분산 장치를 만들 수 있도록 허용하는지 확인합니다. 필요한 할당량을 사용하려면 지원 팀에 문의하세요.
구독에 부하 분산 장치 추가를 지원할 수 있는 충분한 리소스가 있는지 확인합니다. Azure 구독 및 서비스 제한, 할당량 및 제약 조건을 참조하세요.
다음 절차에서는 Resource Manager 템플릿을 사용하여 외부 부하 분산 장치 이동을 준비하고 Azure Portal을 사용하여 외부 부하 분산 장치 구성을 대상 지역으로 이동하는 방법을 보여 줍니다. 먼저 외부 부하 분산 장치의 공용 IP 구성을 내보내야 합니다.
참고
Azure Az PowerShell 모듈을 사용하여 Azure와 상호 작용하는 것이 좋습니다. 시작하려면 Azure PowerShell 설치를 참조하세요. Az PowerShell 모듈로 마이그레이션하는 방법에 대한 자세한 내용은 Azure PowerShell을 AzureRM에서 Azure로 마이그레이션을 참조하세요.
Azure Portal에 로그인하고 리소스 그룹을 선택합니다.
원본 공용 IP를 포함하는 리소스 그룹을 찾아 선택합니다.
설정>템플릿 내보내기를 선택합니다.
템플릿 내보내기에서 배포를 선택합니다.
템플릿>매개 변수 편집을 선택하여 온라인 편집기에서 parameters.json 파일을 엽니다.
공용 IP 이름의 매개 변수를 편집하려면 매개 변수의 값 속성을 원본 공용 IP 이름에서 대상 공용 IP의 이름으로 변경합니다. 이름을 따옴표로 묶습니다.
{ "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#", "contentVersion": "1.0.0.0", "parameters": { "publicIPAddresses_myVM1pubIP_name": { "value": "<target-publicip-name>" } } }
편집기에서 저장을 선택합니다.
템플릿>템플릿 편집을 선택하여 온라인 편집기에서 template.json 파일을 엽니다.
공용 IP가 이동될 대상 지역을 편집하려면 리소스에서 위치 속성을 변경합니다.
"resources": [ { "type": "Microsoft.Network/publicIPAddresses", "apiVersion": "2019-06-01", "name": "[parameters('publicIPAddresses_myPubIP_name')]", "location": "<target-region>", "sku": { "name": "Standard", "tier": "Regional" }, "properties": { "provisioningState": "Succeeded", "resourceGuid": "7549a8f1-80c2-481a-a073-018f5b0b69be", "ipAddress": "52.177.6.204", "publicIPAddressVersion": "IPv4", "publicIPAllocationMethod": "Static", "idleTimeoutInMinutes": 4, "ipTags": [] } } ]
지역 위치 코드를 가져오려면 Azure 위치를 참조하세요. 지역 코드는 공백이 없는 지역 이름입니다. 예를 들어 미국 중부의 코드는 centralus입니다.
또한 원하거나 필요한 경우 요구 사항에 따라 템플릿의 다른 매개 변수를 변경할 수 있습니다.
SKU. template.json 파일에서 sku의 이름 속성을 변경하여 구성의 공용 IP의 SKU를 표준에서 기본으로 또는 기본에서 표준으로 변경할 수 있습니다.
"resources": [ { "type": "Microsoft.Network/publicIPAddresses", "apiVersion": "2019-06-01", "name": "[parameters('publicIPAddresses_myPubIP_name')]", "location": "<target-region>", "sku": { "name": "Standard", "tier": "Regional" },
가용성 영역. zone 속성을 변경하여 공용 IP의 영역을 변경할 수 있습니다. 영역 속성을 지정하지 않으면 공용 IP가 영역 없음으로 만들어집니다. 단일 영역을 지정하여 영역 공용 IP 하나를 만들거나 3개 영역을 모두 지정하여 영역 중복 공용 IP를 만들 수 있습니다.
"resources": [ { "type": "Microsoft.Network/publicIPAddresses", "apiVersion": "2019-06-01", "name": "[parameters('publicIPAddresses_myPubIP_name')]", "location": "<target-region>", "sku": { "name": "Standard", "tier": "Regional" }, "zones": [ "1", "2", "3" ],
공용 IP 할당 방법 및 유휴 제한. publicIPAllocationMethod 속성을 Static에서 Dynamic으로 또는 Dynamic에서 Static으로 변경하여 공용 IP 할당 방법을 변경할 수 있습니다. idleTimeoutInMinutes 속성을 원하는 값으로 변경하여 유휴 시간 제한을 변경할 수 있습니다. 기본값은 4입니다.
"resources": [ { "type": "Microsoft.Network/publicIPAddresses", "apiVersion": "2019-06-01", "name": "[parameters('publicIPAddresses_myPubIP_name')]", "location": "<target-region>", "sku": { "name": "Standard", "tier": "Regional" }, "zones": [ "1", "2", "3" ], "properties": { "provisioningState": "Succeeded", "resourceGuid": "7549a8f1-80c2-481a-a073-018f5b0b69be", "ipAddress": "52.177.6.204", "publicIPAddressVersion": "IPv4", "publicIPAllocationMethod": "Static", "idleTimeoutInMinutes": 4, "ipTags": []
할당 방법 및 유휴 시간 제한 값에 대한 자세한 내용은 공용 IP 주소 만들기, 변경 또는 삭제를 참조하세요.
온라인 편집기에서 저장을 선택합니다.
기본>구독을 선택하여 대상 공용 IP를 배포할 구독을 선택합니다.
기본>리소스 그룹을 선택하여 대상 공용 IP를 배포할 리소스 그룹을 선택합니다. 새로 만들기를 선택하여 대상 공용 IP에 대한 새 리소스 그룹을 만들 수 있습니다. 이름이 기존 원본 공용 IP의 원본 리소스 그룹과 같지 않은지 확인합니다.
기본>위치가 공용 IP를 배포하려는 대상 위치로 설정되어 있는지 확인합니다.
설정 아래에서 이름이 매개 변수 편집기에서 이전에 입력한 이름과 일치하는지 확인합니다.
사용 약관 확인란을 선택합니다.
구매를 선택하여 대상 공용 IP를 배포합니다.
이동 중인 부하 분산 장치에 대해 아웃바운드 NAT에 사용되는 다른 공용 IP가 있는 경우 이전 단계를 반복하여 두 번째 아웃바운드 공용 IP를 대상 지역으로 내보내고 배포합니다.
Azure Portal에 로그인하고 리소스 그룹을 선택합니다.
원본 외부 부하 분산 장치가 포함된 리소스 그룹을 찾아 선택합니다.
설정>템플릿 내보내기를 선택합니다.
템플릿 내보내기에서 배포를 선택합니다.
템플릿>매개 변수 편집을 선택하여 온라인 편집기에서 parameters.json 파일을 엽니다.
외부 부하 분산 장치 이름의 매개 변수를 편집하려면 원본 외부 부하 분산 장치 이름의 값 속성을 대상 외부 부하 분산 장치의 이름으로 변경합니다. 이름을 따옴표로 묶습니다.
"$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#", "contentVersion": "1.0.0.0", "parameters": { "loadBalancers_myLoadbalancer_ext_name": { "value": "<target-external-lb-name>" }, "publicIPAddresses_myPubIP_in_externalid": { "value": "<target-publicIP-resource-ID>" },
이전 단계에서 이동한 대상 공용 IP의 값을 편집하려면 먼저 리소스 ID를 가져온 다음, parameters.json 파일에 붙여넣어야 합니다. 추적 ID를 확인하려면 다음 단계를 따르세요.
다른 브라우저 탭 또는 창에서 Azure Portal에 로그인하고 리소스 그룹을 선택합니다.
이전 단계에서 이동한 공용 IP를 포함하는 대상 리소스 그룹을 찾습니다. 이 폴더를 선택합니다.
설정>속성을 선택합니다.
오른쪽에서 리소스 ID를 강조 표시하고 클립보드에 복사합니다. 또는 리소스 ID 경로 오른쪽의 클립보드로 복사를 선택할 수 있습니다.
다른 브라우저 창이나 탭에서 열려 있는 매개 변수 편집 편집기에서 값 속성에 리소스 ID를 붙여넣습니다.
```json "$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentParameters.json#", "contentVersion": "1.0.0.0", "parameters": { "loadBalancers_myLoadbalancer_ext_name": { "value": "<target-external-lb-name>" }, "publicIPAddresses_myPubIP_in_externalid": { "value": "<target-publicIP-resource-ID>" },
온라인 편집기에서 저장을 선택합니다.
부하 분산 장치에 대한 아웃바운드 NAT 및 아웃바운드 규칙을 구성한 경우 이 파일에서 아웃바운드 공용 IP의 외부 ID에 대한 세 번째 항목을 볼 수 있습니다. 대상 지역에서 이전 단계를 반복하여 아웃바운드 공용 IP에 대한 ID를 가져옵니다. 해당 ID를 parameters.json 파일에 붙여넣습니다.
"$schema": "https://schema.management.azure.com/schemas/2015-01-01/deploymentTemplate.json#", "contentVersion": "1.0.0.0", "parameters": { "loadBalancers_myLoadbalancer_ext_name": { "value": "<target-external-lb-name>", }, "publicIPAddresses_myPubIP_in_externalid": { "value": "<target-publicIP-resource-ID>", }, "publicIPAddresses_myPubIP_out_externalid": { "defaultValue": "<target-publicIP-outbound-resource-ID>", } },
템플릿>템플릿 편집을 선택하여 온라인 편집기에서 template.json 파일을 엽니다.
외부 부하 분산 장치 구성이 이동될 대상 지역을 편집하려면 template.json 파일의 리소스에서 위치 속성을 변경합니다.
"resources": [ { "type": "Microsoft.Network/loadBalancers", "apiVersion": "2019-06-01", "name": "[parameters('loadBalancers_myLoadBalancer_name')]", "location": "<target-external-lb-region>", "sku": { "name": "Standard", "tier": "Regional" },
지역 위치 코드를 가져오려면 Azure 위치를 참조하세요. 지역 코드는 공백이 없는 지역 이름입니다. 예를 들어 미국 중부의 코드는 centralus입니다.
또한 원하거나 필요한 경우 요구 사항에 따라 템플릿의 다른 매개 변수를 변경할 수 있습니다.
SKU. template.json 파일에서 sku의 이름 속성을 변경하여 구성의 외부 부하 분산 장치의 SKU를 표준에서 기본으로 또는 기본에서 표준으로 변경할 수 있습니다.
"resources": [ { "type": "Microsoft.Network/loadBalancers", "apiVersion": "2019-06-01", "name": "[parameters('loadBalancers_myLoadBalancer_name')]", "location": "<target-external-lb-region>", "sku": { "name": "Standard", "tier": "Regional" },
기본 및 표준 SKU 부하 분산 장치 간의 차이점에 대한 자세한 내용은 Azure Standard Load Balancer 개요를 참조하세요.
부하 분산 규칙. template.json 파일의 loadBalancingRules 섹션에서 항목을 추가하거나 제거하여 구성에서 부하 분산 규칙을 추가하거나 제거할 수 있습니다.
"loadBalancingRules": [ { "name": "myInboundRule", "etag": "W/\"39e5e9cd-2d6d-491f-83cf-b37a259d86b6\"", "properties": { "provisioningState": "Succeeded", "frontendIPConfiguration": { "id": "[concat(resourceId('Microsoft.Network/loadBalancers', parameters('loadBalancers_myLoadBalancer_name')), '/frontendIPConfigurations/myfrontendIPinbound')]" }, "frontendPort": 80, "backendPort": 80, "enableFloatingIP": false, "idleTimeoutInMinutes": 4, "protocol": "Tcp", "enableTcpReset": false, "loadDistribution": "Default", "disableOutboundSnat": true, "backendAddressPool": { "id": "[concat(resourceId('Microsoft.Network/loadBalancers', parameters('loadBalancers_myLoadBalancer_name')), '/backendAddressPools/myBEPoolInbound')]" }, "probe": { "id": "[concat(resourceId('Microsoft.Network/loadBalancers', parameters('loadBalancers_myLoadBalancer_name')), '/probes/myHTTPProbe')]" } } } ]
부하 분산 규칙에 대한 자세한 내용은 Azure Load Balancer란? 페이지를 참조하세요.
프로브. template.json 파일의 프로브 섹션에서 항목을 추가하거나 제거하여 구성에서 부하 분산 장치에 대한 프로브를 추가하거나 제거할 수 있습니다.
"probes": [ { "name": "myHTTPProbe", "etag": "W/\"39e5e9cd-2d6d-491f-83cf-b37a259d86b6\"", "properties": { "provisioningState": "Succeeded", "protocol": "Http", "port": 80, "requestPath": "/", "intervalInSeconds": 15, "numberOfProbes": 2 } } ],
자세한 내용은 부하 분산 장치 상태 프로브를 참조하세요.
인바운드 NAT 규칙. template.json 파일의 inboundNatRules 섹션에서 항목을 추가하거나 제거하여 부하 분산 장치에 대한 인바운드 NAT 규칙을 추가하거나 제거할 수 있습니다.
"inboundNatRules": [ { "name": "myInboundNATRule", "etag": "W/\"39e5e9cd-2d6d-491f-83cf-b37a259d86b6\"", "properties": { "provisioningState": "Succeeded", "frontendIPConfiguration": { "id": "[concat(resourceId('Microsoft.Network/loadBalancers', parameters('loadBalancers_myLoadBalancer_name')), '/frontendIPConfigurations/myfrontendIPinbound')]" }, "frontendPort": 4422, "backendPort": 3389, "enableFloatingIP": false, "idleTimeoutInMinutes": 4, "protocol": "Tcp", "enableTcpReset": false } } ]
인바운드 NAT 규칙의 추가 또는 제거를 완료하려면 template.json 파일 끝에 유형 속성으로 규칙이 나타나거나 제거되어야 합니다.
{ "type": "Microsoft.Network/loadBalancers/inboundNatRules", "apiVersion": "2019-06-01", "name": "[concat(parameters('loadBalancers_myLoadBalancer_name'), '/myInboundNATRule')]", "dependsOn": [ "[resourceId('Microsoft.Network/loadBalancers', parameters('loadBalancers_myLoadBalancer_name'))]" ], "properties": { "provisioningState": "Succeeded", "frontendIPConfiguration": { "id": "[concat(resourceId('Microsoft.Network/loadBalancers', parameters('loadBalancers_myLoadBalancer_name')), '/frontendIPConfigurations/myfrontendIPinbound')]" }, "frontendPort": 4422, "backendPort": 3389, "enableFloatingIP": false, "idleTimeoutInMinutes": 4, "protocol": "Tcp", "enableTcpReset": false } }
인바운드 NAT 규칙에 대한 자세한 내용은 Azure Load Balancer란? 페이지를 참조하세요.
아웃바운드 규칙. template.json 파일의 outboundRules 속성을 편집하여 구성에서 아웃바운드 규칙을 추가하거나 제거할 수 있습니다.
"outboundRules": [ { "name": "myOutboundRule", "etag": "W/\"39e5e9cd-2d6d-491f-83cf-b37a259d86b6\"", "properties": { "provisioningState": "Succeeded", "allocatedOutboundPorts": 10000, "protocol": "All", "enableTcpReset": false, "idleTimeoutInMinutes": 15, "backendAddressPool": { "id": "[concat(resourceId('Microsoft.Network/loadBalancers', parameters('loadBalancers_myLoadBalancer_name')), '/backendAddressPools/myBEPoolOutbound')]" }, "frontendIPConfigurations": [ { "id": "[concat(resourceId('Microsoft.Network/loadBalancers', parameters('loadBalancers_myLoadBalancer_name')), '/frontendIPConfigurations/myfrontendIPoutbound')]" } ] } } ]
자세한 내용은 Load Balancer 아웃바운드 규칙을 참조하세요.
온라인 편집기에서 저장을 선택합니다.
기본>구독을 선택하여 대상 외부 부하 분산 장치를 배포할 구독을 선택합니다.
기본>리소스 그룹을 선택하여 대상 부하 분산 장치를 배포할 리소스 그룹을 선택합니다. 새로 만들기를 선택하여 대상 외부 부하 분산 장치에 대한 새 리소스 그룹을 만들 수 있습니다. 또는 공용 IP에 대해 이전에 만든 기존 리소스 그룹을 선택할 수 있습니다. 이름이 기존 원본 외부 부하 분산 장치의 원본 리소스 그룹과 같지 않은지 확인합니다.
기본>위치가 외부 부하 분산 장치를 배포하려는 대상 위치로 설정되어 있는지 확인합니다.
설정 아래에서 이름이 매개 변수 편집기에서 이전에 입력한 이름과 일치하는지 확인합니다. 구성의 모든 공용 IP에 대해 리소스 ID가 채워졌는지 확인합니다.
사용 약관 확인란을 선택합니다.
구매를 선택하여 대상 공용 IP를 배포합니다.
대상 공용 IP 및 외부 부하 분산 장치를 무시하려면 해당 항목이 포함된 리소스 그룹을 삭제합니다. 이렇게 하려면 포털의 대시보드에서 리소스 그룹을 선택한 다음 개요 페이지의 맨 위에서 삭제를 선택합니다.
변경 내용을 커밋하고 공용 IP 및 외부 부하 분산 장치의 이동을 완료하려면 원본 공용 IP 및 외부 부하 분산 장치 또는 리소스 그룹을 삭제합니다. 이렇게 하려면 포털의 대시보드에서 리소스 그룹을 선택한 다음 각 페이지의 맨 위에서 삭제를 선택합니다.
이 자습서에서는 Azure 외부 부하 분산 장치를 한 지역에서 다른 지역으로 이동하고 원본 리소스를 정리했습니다. Azure에서 지역 간 리소스 이동 및 재해 복구에 대한 자세한 내용은 다음을 참조하세요.