ARM 템플릿의 형식 정의
이 문서에서는 ARM 템플릿(Azure Resource Manager 템플릿)에서 정의를 만들고 사용하는 방법을 설명합니다. 고유한 형식을 정의하여 해당 형식을 재사용할 수 있습니다. 형식 정의는 languageVersion 2.0에서만 사용할 수 있습니다.
참고 항목
Visual Studio Code용 Azure Resource Manager 도구 확장의 현재 릴리스에서는 languageVersion 2.0의 향상된 기능을 인식하지 못합니다.
팁
ARM 템플릿과 동일한 기능을 제공하고 구문이 사용하기 더 쉽기 때문에 Bicep를 권장합니다. 자세한 내용은 Bicep의 사용자 정의 데이터 형식을 참조하세요.
최소 선언
모든 형식 정의에는 최소한 이름과 type
또는 $ref
가 필요합니다.
"definitions": {
"demoStringType": {
"type": "string"
},
"demoIntType": {
"type": "int"
},
"demoBoolType": {
"type": "bool"
},
"demoObjectType": {
"type": "object"
},
"demoArrayType": {
"type": "array"
}
}
허용된 값
형식 정의에 허용되는 값을 정의할 수 있습니다. 배열에 허용되는 값을 제공합니다. 허용되는 값 중 하나가 아닌 값이 형식 정의에 전달되면 유효성 검사 중에 배포가 실패합니다.
"definitions": {
"demoEnumType": {
"type": "string",
"allowedValues": [
"one",
"two"
]
}
}
길이 제약 조건
문자열 및 배열 형식 정의의 최소 길이와 최대 길이를 지정할 수 있습니다. 하나 또는 두 개의 제약 조건을 설정할 수 있습니다. 문자열의 경우 길이는 문자 수를 나타냅니다. 배열의 경우 길이는 배열의 항목 수를 나타냅니다.
다음 예제에서는 두 가지 형식 정의를 선언합니다. 한 가지 형식 정의는 스토리지 계정 이름에 대한 것이며, 3~24자여야 합니다. 다른 형식 정의는 배열이며, 1~5개 항목이 있어야 합니다.
"definitions": {
"storageAccountNameType": {
"type": "string",
"minLength": 3,
"maxLength": 24
},
"appNameType": {
"type": "array",
"minLength": 1,
"maxLength": 5
}
}
정수 제약 조건
정수 형식 정의의 최솟값과 최댓값을 설정할 수 있습니다. 하나 또는 두 개의 제약 조건을 설정할 수 있습니다.
"definitions": {
"monthType": {
"type": "int",
"minValue": 1,
"maxValue": 12
}
}
개체 제약 조건
속성
properties
값은 속성 이름 => 형식 정의의 맵입니다.
다음 예제에서는 {"foo": "string", "bar": 1}
을 허용하지만 {"foo": "string", "bar": -1}
, {"foo": "", "bar": 1}
또는 foo
나 bar
속성이 없는 개체는 거부합니다.
"definitions": {
"objectDefinition": {
"type": "object",
"properties": {
"foo": {
"type": "string",
"minLength": 3
},
"bar": {
"type": "int",
"minValue": 0
}
}
}
},
"parameters": {
"objectParameter": {
"$ref": "#/definitions/objectDefinition",
}
}
속성의 형식 정의에 "nullable": true 제약 조건이 없는 한 모든 속성은 필수입니다. 앞의 예제에서 두 속성을 모두 선택 사항으로 만들려면 다음과 같습니다.
"definitions": {
"objectDefinition": {
"type": "object",
"properties": {
"foo": {
"type": "string",
"minLength": 3,
"nullable": true
},
"bar": {
"type": "int",
"minValue": 0,
"nullable": true
}
}
}
}
additionalProperties
additionalProperties
값은 형식 정의 또는 부울 값입니다. additionalProperties
제약 조건이 정의되지 않은 경우 기본값은 true
입니다.
값이 형식 정의인 경우 값은 properties
제약 조건에 언급되지 않은 모든 속성에 적용되는 스키마를 설명합니다. 다음 예제에서는 {"fizz": "buzz", "foo": "bar"}
를 허용하지만 {"property": 1}
은 거부합니다.
"definitions": {
"dictionaryDefinition": {
"type": "object",
"properties": {
"foo": {
"type": "string",
"minLength": 3,
"nullable": true
},
"bar": {
"type": "int",
"minValue": 0,
"nullable": true
}
},
"additionalProperties": {
"type": "string"
}
}
}
값이 false
이면 properties
제약 조건에 정의된 속성 이외의 속성은 제공할 수 없습니다. 다음 예제에서는 {"foo": "string", "bar": 1}
을 허용하지만 {"foo": "string", "bar": 1, "fizz": "buzz"}
는 거부합니다.
"definitions": {
"dictionaryDefinition": {
"type": "object",
"properties": {
"foo": {
"type": "string",
"minLength": 3
},
"bar": {
"type": "int",
"minValue": 0
}
},
"additionalProperties": false
}
}
값이 true
이면 properties
제약 조건에 정의되지 않은 모든 속성은 모든 값을 허용합니다. 다음 예제에서는 {"foo": "string", "bar": 1, "fizz": "buzz"}
를 허용합니다.
"definitions": {
"dictionaryDefinition": {
"type": "object",
"properties": {
"foo": {
"type": "string",
"minLength": 3
},
"bar": {
"type": "int",
"minValue": 0
}
},
"additionalProperties": true
}
}
discriminator
discriminator
값은 판별자 속성을 기반으로 적용할 스키마를 정의합니다. 다음 예제에서는 {"type": "ints", "foo": 1, "bar": 2}
또는 {"type": "strings", "fizz": "buzz", "pop": "goes", "the": "weasel"}
을 허용하지만 {"type": "ints", "fizz": "buzz"}
는 거부합니다.
"definitions": {
"taggedUnionDefinition": {
"type": "object",
"discriminator": {
"propertyName": "type",
"mapping": {
"ints": {
"type": "object",
"additionalProperties": {"type": "int"}
},
"strings": {
"type": "object",
"additionalProperties": {"type": "string"}
}
}
}
}
}
배열 제약 조건
prefixItems
prefixItems
값은 형식 정의의 배열입니다. 값의 각 형식 정의는 동일한 인덱스에 있는 배열 요소의 유효성을 검사하는 데 사용되는 스키마입니다. 다음 예제에서는 [1, true]
를 허용하지만 [1, "string"]
또는 [1]
은 거부합니다.
"definitions": {
"tupleDefinition": {
"type": "array",
"prefixItems": [
{ "type": "int" },
{ "type": "bool" }
]
}
},
"parameters": {
"tupleParameter": {
"$ref": "#/definitions/tupleDefinition"
}
}
항목
items
값은 형식 정의 또는 부울 값입니다. items
제약 조건이 정의되지 않은 경우 기본값은 true
입니다.
값이 형식 정의인 경우 이 값은 인덱스가 prefixItems
제약 조건의 가장 큰 인덱스보다 큰 배열의 모든 요소에 적용되는 스키마를 설명합니다. 다음 예제에서는 [1, true, 1]
또는 [1, true, 1, 1]
을 허용하지만 [1, true, "foo"]
는 거부합니다.
"definitions": {
"tupleDefinition": {
"type": "array",
"prefixItems": [
{ "type": "int" },
{ "type": "bool" }
],
"items": { "type": "int" }
}
},
"parameters": {
"tupleParameter": {
"$ref": "#/definitions/tupleDefinition"
}
}
prefixItems
를 사용하지 않고 items
를 사용할 수 있습니다. 다음 예제에서는 [1, 2]
또는 [1]
을 허용하지만 ["foo"]
는 거부합니다.
"definitions": {
"intArrayDefinition": {
"type": "array",
"items": { "type": "int" }
}
},
"parameters": {
"intArrayParameter": {
"$ref": "#/definitions/intArrayDefinition"
}
}
값이 false
인 경우 유효성이 검사된 배열은 prefixItems
제약 조건과 정확히 동일한 길이여야 합니다. 다음 예제에서는 [1, true]
를 허용하지만 [1, true, 1]
및 [1, true, false, "foo", "bar"]
는 거부합니다.
"definitions": {
"tupleDefinition": {
"type": "array",
"prefixItems": [
{"type": "int"},
{"type": "bool"}
]
},
"items": false
}
값이 true이면 인덱스가 prefixItems
제약 조건의 가장 큰 인덱스보다 큰 배열 요소는 모든 값을 허용합니다. 다음 예제에서는 [1, true]
, [1, true, 1]
및 [1, true, false, "foo", "bar"]
를 허용합니다.
"definitions": {
"tupleDefinition": {
"type": "array",
"prefixItems": [
{"type": "int"},
{"type": "bool"}
]
}
}
"definitions": {
"tupleDefinition": {
"type": "array",
"prefixItems": [
{"type": "int"},
{"type": "bool"}
]
},
"items": true
}
nullable 제약 조건
nullable 제약 조건은 값이 null
이거나 생략될 수 있음을 나타냅니다. 예제는 속성을 참조하세요.
설명
형식 정의에 description을 추가하면 템플릿 사용자가 제공할 값을 이해하는 데 도움이 됩니다.
"definitions": {
"virtualMachineSize": {
"type": "string",
"metadata": {
"description": "Must be at least Standard_A3 to support 2 NICs."
},
"defaultValue": "Standard_DS1_v2"
}
}
정의 사용
형식 정의를 참조하려면 다음 구문을 사용합니다.
"$ref": "#/definitions/<definition-name>"
다음 예제에서는 parameters 및 outputs에서 형식 정의를 참조하는 방법을 보여줍니다.
{
"$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
"contentVersion": "1.0.0.0",
"languageVersion": "2.0",
"definitions": {
"naturalNumber": {
"type": "int",
"minValue": 1
}
},
"parameters": {
"numberParam": {
"$ref": "#/definitions/naturalNumber",
"defaultValue": 0
}
},
"resources": {},
"outputs": {
"output1": {
"$ref": "#/definitions/naturalNumber",
"value": "[parameters('numberParam')]"
}
}
}
다음 단계
- 형식 정의에 사용할 수 있는 속성에 대한 자세한 내용은 ARM 템플릿의 구조 및 구문 이해를 참조하세요.