다음을 통해 공유


ARM 템플릿의 논리 함수

Resource Manager는 ARM 템플릿(Azure Resource Manager 템플릿)에서 비교를 수행하기 위한 몇 가지 함수를 제공합니다.

ARM 템플릿과 동일한 기능을 제공하고 구문이 사용하기 더 쉽기 때문에 Bicep를 권장합니다. 자세한 내용은 부울 논리 함수 및 논리 연산자를 참조하세요.

and(arg1, arg2, ...)

모든 매개 변수 값이 True인지 확인합니다.

and 함수는 Bicep에서 지원되지 않습니다. 대신 ?: 연산자를 사용합니다.

매개 변수

매개 변수 필수 Type 설명
arg1 부울 값 true인지 확인할 첫 번째 값입니다.
arg2 부울 값 true인지 확인할 두 번째 값입니다.
더 많은 인수 아니요 부울 값 true인지 확인할 추가 인수입니다.

반환 값

모든 값이 True이면 True를 반환하고 그렇지 않으면 False를 반환합니다.

예제

다음 예제에서는 논리 함수를 사용하는 방법을 보여 줍니다.

{
  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
  "contentVersion": "1.0.0.0",
  "resources": [],
  "outputs": {
    "andExampleOutput": {
      "type": "bool",
      "value": "[and(bool('true'), bool('false'))]"
    },
    "orExampleOutput": {
      "type": "bool",
      "value": "[or(bool('true'), bool('false'))]"
    },
    "notExampleOutput": {
      "type": "bool",
      "value": "[not(bool('true'))]"
    }
  }
}

위 예제의 출력은 다음과 같습니다.

이름 타입
andExampleOutput Bool False
orExampleOutput Bool True
notExampleOutput Bool False

bool

bool(arg1)

매개 변수를 부울로 변환합니다.

Bicep에서 bool 논리 함수를 사용합니다.

매개 변수

매개 변수 필수 Type 설명
arg1 문자열 또는 int 부울로 변환할 값입니다.

반환 값

변환된 값의 부울입니다.

설명

true()false()를 사용하여 부울 값을 가져올 수도 있습니다.

예제

다음 예제에서는 문자열 또는 정수에 bool을 사용하는 방법을 보여 줍니다.

{
  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
  "contentVersion": "1.0.0.0",
  "resources": [],
  "outputs": {
    "trueString": {
      "type": "bool",
      "value": "[bool('true')]"
    },
    "falseString": {
      "type": "bool",
      "value": "[bool('false')]"
    },
    "trueInt": {
      "type": "bool",
      "value": "[bool(1)]"
    },
    "falseInt": {
      "type": "bool",
      "value": "[bool(0)]"
    }
  }
}

기본 값을 사용한 이전 예제의 출력은 다음과 같습니다.

이름 타입
trueString Bool True
falseString Bool False
trueInt Bool True
falseInt Bool False

false

false()

false를 반환합니다.

false 함수는 Bicep에서 사용할 수 없습니다. 대신 false 키워드를 사용합니다.

매개 변수

false 함수는 매개 변수를 허용하지 않습니다.

반환 값

항상 false인 부울입니다.

예시

다음 예에서는 false 출력 값을 반환합니다.

{
  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
  "contentVersion": "1.0.0.0",
  "resources": [],
  "outputs": {
    "falseOutput": {
      "type": "bool",
      "value": "[false()]"
    }
  }
}

위 예제의 출력은 다음과 같습니다.

이름 타입
falseOutput Bool False

if

if(condition, trueValue, falseValue)

조건이 true인지 아니면 false인지에 따라 값을 반환합니다.

if 함수는 Bicep에서 지원되지 않습니다. 대신 ?: 연산자를 사용합니다.

매개 변수

매개 변수 필수 Type 설명
condition 부울 값 true인지 false인지 확인할 값입니다.
trueValue 문자열, 정수, 개체 또는 배열 조건이 true이면 반환할 값입니다.
falseValue 문자열, 정수, 개체 또는 배열 조건이 false이면 반환할 값입니다.

반환 값

첫 번째 매개 변수가 True이면 두 번째 매개 변수를 반환하고 그렇지 않으면 세 번째 매개 변수를 반환합니다.

설명

조건이 true이면 true 값만 평가됩니다. 조건이 false이면 false 값만 평가됩니다. if 함수를 사용하여 조건부로 유효한 식만 포함할 수 있습니다. 예를 들어, 한 조건에는 있지만 다른 조건에는 없는 리소스를 참조할 수 있습니다. 조건에 따라 식을 평가하는 예는 다음 섹션에 나와 있습니다.

위의 규칙은 템플릿 배포 프로세스가 시작될 때 조건을 평가할 수 있는 경우에만 적용됩니다. 예를 들어 조건에서는 reference() 사용할 수 없습니다.

예제

다음 예제에서는 if 함수를 사용하는 방법을 보여 줍니다.

{
  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
  "contentVersion": "1.0.0.0",
  "resources": [
  ],
  "outputs": {
    "yesOutput": {
      "type": "string",
      "value": "[if(equals('a', 'a'), 'yes', 'no')]"
    },
    "noOutput": {
      "type": "string",
      "value": "[if(equals('a', 'b'), 'yes', 'no')]"
    },
    "objectOutput": {
      "type": "object",
      "value": "[if(equals('a', 'a'), json('{\"test\": \"value1\"}'), json('null'))]"
    }
  }
}

위 예제의 출력은 다음과 같습니다.

이름 타입
yesOutput 문자열
noOutput 문자열 아니요
objectOutput Object { "test": "value1" }

다음 예제 템플릿에서는 조건부로 유효한 식에서만 이 함수를 사용하는 방법을 보여 줍니다.

{
  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
  "contentVersion": "1.0.0.0",
  "parameters": {
    "vmName": {
      "type": "string"
    },
    "location": {
      "type": "string"
    },
    "logAnalytics": {
      "type": "string",
      "defaultValue": ""
    }
  },
  "resources": [
   {
      "condition": "[not(empty(parameters('logAnalytics')))]",
      "type": "Microsoft.Compute/virtualMachines/extensions",
      "apiVersion": "2022-11-01",
      "name": "[format('{0}/omsOnboarding', parameters('vmName'))]",
      "location": "[parameters('location')]",
      "properties": {
        "publisher": "Microsoft.EnterpriseCloud.Monitoring",
        "type": "MicrosoftMonitoringAgent",
        "typeHandlerVersion": "1.0",
        "autoUpgradeMinorVersion": true,
        "settings": {
          "workspaceId": "[if(not(empty(parameters('logAnalytics'))), reference(parameters('logAnalytics'), '2015-11-01-preview').customerId, null())]"
        },
        "protectedSettings": {
          "workspaceKey": "[if(not(empty(parameters('logAnalytics'))), listKeys(parameters('logAnalytics'), '2015-11-01-preview').primarySharedKey, null())]"
        }
      }
    }
  ],
  "outputs": {
    "mgmtStatus": {
      "type": "string",
      "value": "[if(not(empty(parameters('logAnalytics'))), 'Enabled monitoring for VM!', 'Nothing to enable')]"
    }
  }
}

not

not(arg1)

부울 값을 반대 값으로 변환합니다.

not 함수는 Bicep에서 지원되지 않습니다. 대신 ! 연산자를 사용합니다.

매개 변수

매개 변수 필수 Type 설명
arg1 부울 값 변환할 값입니다.

반환 값

매개 변수가 False이면 True를 반환합니다. 매개 변수가 True이면 False를 반환합니다.

예제

다음 예제에서는 논리 함수를 사용하는 방법을 보여 줍니다.

{
  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
  "contentVersion": "1.0.0.0",
  "resources": [],
  "outputs": {
    "andExampleOutput": {
      "type": "bool",
      "value": "[and(bool('true'), bool('false'))]"
    },
    "orExampleOutput": {
      "type": "bool",
      "value": "[or(bool('true'), bool('false'))]"
    },
    "notExampleOutput": {
      "type": "bool",
      "value": "[not(bool('true'))]"
    }
  }
}

위 예제의 출력은 다음과 같습니다.

이름 타입
andExampleOutput Bool False
orExampleOutput Bool True
notExampleOutput Bool False

다음 예제에서는 equalsnot를 사용합니다.

{
  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
  "contentVersion": "1.0.0.0",
  "resources": [
  ],
  "outputs": {
    "checkNotEquals": {
      "type": "bool",
      "value": "[not(equals(1, 2))]"
    }
  }
}

위 예제의 출력은 다음과 같습니다.

이름 타입
checkNotEquals Bool True

또는

or(arg1, arg2, ...)

매개 변수 값 중 하나가 True인지 확인합니다.

or 함수는 Bicep에서 지원되지 않습니다. 대신 || 연산자를 사용합니다.

매개 변수

매개 변수 필수 Type 설명
arg1 부울 값 true인지 확인할 첫 번째 값입니다.
arg2 부울 값 true인지 확인할 두 번째 값입니다.
더 많은 인수 아니요 부울 값 true인지 확인할 추가 인수입니다.

반환 값

True인 값이 하나라도 있으면 True를 반환하고 그렇지 않으면 False를 반환합니다.

예제

다음 예제에서는 논리 함수를 사용하는 방법을 보여 줍니다.

{
  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
  "contentVersion": "1.0.0.0",
  "resources": [],
  "outputs": {
    "andExampleOutput": {
      "type": "bool",
      "value": "[and(bool('true'), bool('false'))]"
    },
    "orExampleOutput": {
      "type": "bool",
      "value": "[or(bool('true'), bool('false'))]"
    },
    "notExampleOutput": {
      "type": "bool",
      "value": "[not(bool('true'))]"
    }
  }
}

위 예제의 출력은 다음과 같습니다.

이름 타입
andExampleOutput Bool False
orExampleOutput Bool True
notExampleOutput Bool False

true

true()

true를 반환합니다.

true 함수는 Bicep에서 사용할 수 없습니다. 대신 true 키워드를 사용합니다.

매개 변수

true 함수는 매개 변수를 허용하지 않습니다.

반환 값

항상 true인 부울입니다.

예시

다음 예에서는 true 출력 값을 반환합니다.

{
  "$schema": "https://schema.management.azure.com/schemas/2019-04-01/deploymentTemplate.json#",
  "contentVersion": "1.0.0.0",
  "resources": [],
  "outputs": {
    "trueOutput": {
      "type": "bool",
      "value": "[true()]"
    }
  }
}

위 예제의 출력은 다음과 같습니다.

이름 타입
trueOutput Bool True

다음 단계