Azure Resource Manager 배포 모드

리소스를 배포할 때 배포를 증분 업데이트 또는 전체 업데이트할지 지정합니다. 이러한 두 모드 간 차이점은 Resource Manager가 템플릿에 없는 리소스 그룹에서 기존 리소스를 처리하는 방식입니다.

두 모드에서 모두, Resource Manager는 템플릿에 지정된 모든 리소스를 만들려고 합니다. 리소스 그룹에 이미 리소스가 있고 해당 설정이 변경되지 않은 경우 해당 리소스에 대한 작업이 수행되지 않습니다. 리소스의 속성 값을 변경하는 경우 리소스가 새 값으로 업데이트됩니다. 기존 리소스의 위치 또는 종류를 업데이트하려고 하면 오류가 발생하여 배포에 실패합니다. 대신, 새 리소스를 필요한 위치 또는 유형으로 배포합니다.

기본 모드는 증분입니다.

전체 모드

전체 모드에서는 Resource Manager가 리소스 그룹에 존재하지만 템플릿에는 지정되지 않은 리소스를 삭제합니다.

참고 항목

템플릿을 전체 모드로 배포하기 전에 항상 가상 작업을 사용합니다. 가상은 삭제 또는 수정되는 리소스를 표시합니다. 리소스를 실수로 삭제하지 않도록 하려면 가상을 사용합니다.

조건이 false로 평가되므로 템플릿에 배포되지 않은 리소스가 포함된 경우에는 템플릿을 배포하는 데 사용하는 REST API 버전에 따라 결과가 달라집니다. 2019년 5월 10일 이전 버전을 사용하는 경우 리소스는 삭제되지 않습니다. 2019년 5월 10일 이후 버전에서는 리소스가 삭제됩니다. 최신 버전의 Azure PowerShell 및 Azure CLI는 리소스를 삭제합니다.

복사 루프에서 전체 모드를 사용할 때는 주의해야 합니다. 복사 루프를 확인한 후 템플릿에 지정되지 않은 모든 리소스는 삭제됩니다.

템플릿에서 둘 이상의 리소스 그룹에 배포하는 경우 배포 작업에 지정된 리소스 그룹의 리소스를 삭제할 수 있습니다. 보조 리소스 그룹의 리소스는 삭제되지 않습니다.

리소스 종류에서 전체 모드 삭제를 처리하는 방법에는 몇 가지 차이점이 있습니다. 전체 모드로 배포된 템플릿에 없는 경우 부모 리소스가 자동으로 삭제됩니다. 일부 자식 리소스는 템플릿에 없더라도 자동으로 삭제되지 않습니다. 그러나 부모 리소스가 삭제되면 이러한 자식 리소스도 삭제됩니다.

예를 들어 리소스 그룹에 DNS 영역(Microsoft.Network/dnsZones 리소스 종류)과 CNAME 레코드(Microsoft.Network/dnsZones/CNAME 리소스 종류)가 포함된 경우 DNS 영역은 CNAME 레코드의 부모 리소스입니다. 전체 모드로 배포하고 템플릿에 DNS 영역을 포함하지 않으면 DNS 영역과 CNAME 레코드가 둘 다 삭제됩니다. 템플릿에 DNS 영역을 포함하지만 CNAME 레코드를 포함하지 않으면 CNAME은 삭제되지 않습니다.

리소스 종류의 삭제 처리 방식에 대한 목록은 전체 모드 배포에 대한 Azure 리소스 삭제를 참조하세요.

리소스 그룹이 잠긴 경우, 전체 모드에서 리소스를 삭제하지 않습니다.

참고 항목

루트 수준 템플릿만 전체 배포 모드를 지원합니다. 연결된 또는 중첩된 템플릿의 경우 증분 모드만 사용해야 합니다.

구독 수준 배포는 전체 모드를 지원하지 않습니다.

현재 포털은 전체 모드를 지원하지 않습니다.

증분 모드

증분 모드에서는 Resource Manager가 리소스 그룹에 존재하지만 템플릿에는 지정되지 않은 리소스를 변경하지 않고 유지합니다. 템플릿의 리소스는 리소스 그룹에 ‘추가’됩니다.

Important

증분 모드에서 기존 리소스를 다시 배포하는 경우 모든 속성이 다시 적용됩니다. 속성은 증분 방식으로 추가되지 않습니다. 일반적인 오해는 템플릿에 지정되지 않은 속성은 변경되지 않는다고 생각하는 것입니다. 특정 속성을 지정하지 않을 경우 Resource Manager는 배포를 해당 값을 덮어쓰는 것으로 해석합니다. 템플릿에 포함되지 않은 속성은 기본값으로 다시 설정됩니다. 업데이트하는 것뿐만 아니라 리소스에 대해 기본값이 아닌 모든 값을 지정합니다. 템플릿의 리소스 정의는 항상 리소스의 최종 상태를 포함합니다. 기존 리소스에 대한 부분 업데이트를 나타낼 수 없습니다.

Warning

드문 경우에서 리소스 또는 해당 자식 리소스 중 하나에 속성을 지정할 수 있습니다. 두 가지 일반적인 예는 가상 네트워크의 서브넷웹앱에 대한 사이트 구성 값입니다. 이러한 경우 증분 업데이트를 신중하게 처리해야 합니다.

서브넷의 경우 Microsoft.Network/virtualNetworks 리소스의 subnets 속성을 통해 값을 지정합니다. 자식 리소스 Microsoft.Network/virtualNetworks/subnets를 통해 값을 정의하지 않습니다. 서브넷이 가상 네트워크에 정의되어 있는 한 가상 네트워크를 다시 배포하고 서브넷을 잃지 않을 수 있습니다.

사이트 구성 값의 경우 값은 자식 리소스 유형 Microsoft.Web/sites/config에서 구현됩니다. 웹앱을 다시 배포하고 사이트 구성 값에 대해 빈 개체를 지정하면 자식 리소스가 업데이트되지 않습니다. 그러나 새 사이트 구성 값을 제공하는 경우 자식 리소스 종류가 업데이트됩니다.

결과 예제

증분 및 전체 모드 간의 차이를 보여주려면 다음 시나리오를 고려합니다.

리소스 그룹은 다음 항목을 포함합니다.

  • 리소스 A
  • 리소스 B
  • 리소스 C

템플릿은 다음 항목을 포함합니다.

  • 리소스 A
  • 리소스 B
  • 리소스 D

리소스 그룹이 증분 모드로 배포된 경우 다음 항목을 포함합니다.

  • 리소스 A
  • 리소스 B
  • 리소스 C
  • 리소스 D

리소스 C가 전체 모드로 배포된 경우 삭제됩니다. 리소스 그룹은 다음 항목을 포함합니다.

  • 리소스 A
  • 리소스 B
  • 리소스 D

배포 모드 설정

PowerShell을 사용하여 배포하는 경우 배포 모드를 설정하려면 Mode 매개 변수를 사용합니다.

New-AzResourceGroupDeployment `
  -Mode Complete `
  -Name ExampleDeployment `
  -ResourceGroupName ExampleResourceGroup `
  -TemplateFile c:\MyTemplates\storage.json

Azure CLI를 사용하여 배포하는 경우 배포 모드를 설정하려면 mode 매개 변수를 사용합니다.

az deployment group create \
  --mode Complete \
  --name ExampleDeployment \
  --resource-group ExampleResourceGroup \
  --template-file storage.json

다음 예제에서는 증분 배포 모드로 연결된 템플릿 세트를 보여줍니다.

"resources": [
  {
    "type": "Microsoft.Resources/deployments",
    "apiVersion": "2020-10-01",
    "name": "linkedTemplate",
    "properties": {
      "mode": "Incremental",
          <nested-template-or-external-template>
    }
  }
]

다음 단계