ARM 템플릿의 속성 반복
이 문서에서는 ARM 템플릿(Azure Resource Manager 템플릿)에서 속성의 인스턴스를 두 개 이상 만드는 방법을 보여 줍니다. 템플릿에서 리소스의 속성 섹션에 복사 루프를 추가하여 배포 중에 속성의 항목 수를 동적으로 설정할 수 있습니다. 템플릿 구문을 반복하지 않아도 됩니다.
속성에 복사 루프를 적용하는 경우에도 최상위 리소스와 함께 복사 루프를 사용할 수 있습니다. 자식 리소스를 최상위 수준 리소스로 변경하는 방법에 대해 자세히 알아보려면 자식 리소스에 대한 반복을 참조하세요.
리소스, 변수 및 출력과 함께 복사 루프를 사용할 수도 있습니다.
구문
템플릿의 리소스 섹션에 copy
요소를 추가하여 속성의 항목 수를 설정합니다. 복사 요소의 일반적인 형식은 다음과 같습니다.
"copy": [
{
"name": "<name-of-property>",
"count": <number-of-iterations>,
"input": <values-for-the-property>
}
]
name
의 경우 만들려는 리소스 속성의 이름을 입력합니다.
count
속성은 속성에 대해 원하는 반복 횟수를 지정합니다.
input
속성은 반복할 속성을 지정합니다. input
속성의 값에서 생성된 요소 배열을 만듭니다.
복사 제한
개수는 800개를 초과할 수 없습니다.
개수는 음수가 될 수 없습니다. 최신 버전의 Azure CLI, PowerShell 또는 REST API를 사용하여 템플릿을 배포하는 경우에는 0이 될 수 있습니다. 특히 다음을 사용해야 합니다.
- Azure PowerShell 2.6 이상
- Azure CLI 2.0.74 이상
- REST API 버전 2019-05-10 이상
- 연결된 배포는 배포 리소스 유형에 API 버전 2019-05-10 이상을 사용해야 합니다.
이전 버전의 PowerShell, CLI 및 REST API는 개수에 0을 지원하지 않습니다.
속성 반복
다음 예제는 가상 머신에서 복사 루프를 dataDisks
속성에 적용하는 방법을 보여 줍니다.
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"numberOfDataDisks": {
"type": "int",
"minValue": 0,
"maxValue": 16,
"defaultValue": 3,
"metadata": {
"description": "The number of dataDisks to create."
}
},
...
},
"resources": [
{
"type": "Microsoft.Compute/virtualMachines",
"apiVersion": "2022-11-01",
...
"properties": {
"storageProfile": {
...
"copy": [
{
"name": "dataDisks",
"count": "[parameters('numberOfDataDisks')]",
"input": {
"lun": "[copyIndex('dataDisks')]",
"createOption": "Empty",
"diskSizeGB": 1023
}
}
]
}
...
}
}
]
}
속성 반복 내에서 copyIndex를 사용하는 경우 반복의 이름을 제공해야 합니다. 또한 속성 반복은 오프셋 인수를 지원합니다. 오프셋은 copyIndex('dataDisks', 1)
와 같은 반복 이름 뒤에 와야 합니다.
배포된 템플릿은 다음과 같습니다.
{
"name": "examplevm",
"type": "Microsoft.Compute/virtualMachines",
"apiVersion": "2020-06-01",
"properties": {
"storageProfile": {
"dataDisks": [
{
"lun": 0,
"createOption": "Empty",
"diskSizeGB": 1023
},
{
"lun": 1,
"createOption": "Empty",
"diskSizeGB": 1023
},
{
"lun": 2,
"createOption": "Empty",
"diskSizeGB": 1023
}
],
...
복사 작업은 배열의 각 요소를 반복할 수 있으므로 배열을 사용할 때 유용합니다. 배열의 length 함수를 사용하여 반복 횟수를 지정하고, copyIndex
를 사용하여 배열의 현재 인덱스를 검색합니다.
다음 예제 템플릿에서는 배열로 전달되는 데이터베이스에 대한 장애 조치(failover) 그룹을 만듭니다.
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"parameters": {
"primaryServerName": {
"type": "string"
},
"secondaryServerName": {
"type": "string"
},
"databaseNames": {
"type": "array",
"defaultValue": [
"mydb1",
"mydb2",
"mydb3"
]
}
},
"variables": {
"failoverName": "[format('{0}/{1}failovergroups', parameters('primaryServerName'), parameters('primaryServerName'))]"
},
"resources": [
{
"type": "Microsoft.Sql/servers/failoverGroups",
"apiVersion": "2015-05-01-preview",
"name": "[variables('failoverName')]",
"properties": {
"readWriteEndpoint": {
"failoverPolicy": "Automatic",
"failoverWithDataLossGracePeriodMinutes": 60
},
"readOnlyEndpoint": {
"failoverPolicy": "Disabled"
},
"partnerServers": [
{
"id": "[resourceId('Microsoft.Sql/servers', parameters('secondaryServerName'))]"
}
],
"copy": [
{
"name": "databases",
"count": "[length(parameters('databaseNames'))]",
"input": "[resourceId('Microsoft.Sql/servers/databases', parameters('primaryServerName'), parameters('databaseNames')[copyIndex('databases')])]"
}
]
}
}
],
"outputs": {
}
}
copy
요소는 배열이므로 리소스에 대해 2개 이상의 속성을 지정할 수 있습니다.
{
"type": "Microsoft.Network/loadBalancers",
"apiVersion": "2017-10-01",
"name": "exampleLB",
"properties": {
"copy": [
{
"name": "loadBalancingRules",
"count": "[length(parameters('loadBalancingRules'))]",
"input": {
...
}
},
{
"name": "probes",
"count": "[length(parameters('loadBalancingRules'))]",
"input": {
...
}
}
]
}
}
리소스 및 속성 반복을 함께 사용할 수 있습니다. 이름별로 속성 반복을 참조하세요.
{
"type": "Microsoft.Network/virtualNetworks",
"apiVersion": "2018-04-01",
"name": "[format('{0}{1}', parameters('vnetname'), copyIndex())]",
"copy":{
"count": 2,
"name": "vnetloop"
},
"location": "[resourceGroup().location]",
"properties": {
"addressSpace": {
"addressPrefixes": [
"[parameters('addressPrefix')]"
]
},
"copy": [
{
"name": "subnets",
"count": 2,
"input": {
"name": "[format('subnet-{0}', copyIndex('subnets'))]",
"properties": {
"addressPrefix": "[variables('subnetAddressPrefix')[copyIndex('subnets')]]"
}
}
}
]
}
}
예제 템플릿
다음 예제에서는 속성에 대한 값을 두 개 이상 만드는 일반적인 시나리오를 보여 줍니다.
템플릿 | 설명 |
---|---|
가변적인 수의 데이터 디스크를 사용한 VM 배포 | 가상 머신을 사용하여 여러 데이터 디스크를 배포합니다. |
다음 단계
- 자습서를 살펴보려면 자습서: ARM 템플릿을 사용하여 여러 리소스 인스턴스 만들기를 참조하세요.
- 복사 루프의 다른 용도는 다음을 참조하세요.
- 템플릿의 섹션에 대해 알아보려면 ARM 템플릿의 구조 및 구문 이해를 참조하세요.
- 템플릿을 배포하는 방법을 자세히 알아보려면 ARM 템플릿 및 Azure PowerShell을 사용하여 리소스 배포를 참조하세요.