다음을 통해 공유


Event Grid 구독에 대한 이벤트 필터링 이해

이 문서에서는 엔드포인트에 전송되는 이벤트를 필터링하는 다양한 방법을 설명합니다. 이벤트 구독을 만들 때 필터링에 대한 세 가지 옵션이 있습니다.

  • 일정 유형
  • 다음 값으로 시작하거나 끝나는 제목
  • 고급 필드 및 연산자

Azure Resource Manager 템플릿

이 문서에 표시된 예제는 ARM(Azure Resource Manager) 템플릿에서 필터를 정의하기 위한 JSON 코드 조각입니다. 전체 ARM 템플릿 및 ARM 템플릿 배포의 예제는 빠른 시작: ARM 템플릿을 사용하여 Blob 스토리지 이벤트를 웹 엔드포인트로 라우팅을 참조하세요. 다음은 빠른 시작 예제의 filter 섹션에 대한 몇 가지 추가 섹션입니다. ARM 템플릿은 다음 리소스를 정의합니다.

  • Azure Storage 계정
  • 스토리지 계정에 대한 시스템 항목
  • 시스템 항목에 대한 이벤트 구독입니다. 이벤트 구독 섹션의 filter 하위 섹션을 참조하세요.

다음 예제에서 이벤트 구독은 Microsoft.Storage.BlobCreatedMicrosoft.Storage.BlobDeleted 이벤트를 필터링합니다.

{
  "resources": [
    {
      "type": "Microsoft.Storage/storageAccounts",
      "apiVersion": "2021-08-01",
      "name": "[parameters('storageAccountName')]",
      "location": "[parameters('location')]",
      "sku": {
        "name": "Standard_LRS"
      },
      "kind": "StorageV2",
      "properties": {
        "accessTier": "Hot"
      }
    },
    {
      "type": "Microsoft.EventGrid/systemTopics",
      "apiVersion": "2021-12-01",
      "name": "[parameters('systemTopicName')]",
      "location": "[parameters('location')]",
      "properties": {
        "source": "[resourceId('Microsoft.Storage/storageAccounts', parameters('storageAccountName'))]",
        "topicType": "Microsoft.Storage.StorageAccounts"
      },
      "dependsOn": [
        "[resourceId('Microsoft.Storage/storageAccounts', parameters('storageAccountName'))]"
      ]
    },
    {
      "type": "Microsoft.EventGrid/systemTopics/eventSubscriptions",
      "apiVersion": "2021-12-01",
      "name": "[format('{0}/{1}', parameters('systemTopicName'), parameters('eventSubName'))]",
      "properties": {
        "destination": {
          "properties": {
            "endpointUrl": "[parameters('endpoint')]"
          },
          "endpointType": "WebHook"
        },
        "filter": {
          "includedEventTypes": [
            "Microsoft.Storage.BlobCreated",
            "Microsoft.Storage.BlobDeleted"
          ]
        }
      },
      "dependsOn": [
        "[resourceId('Microsoft.EventGrid/systemTopics', parameters('systemTopicName'))]"
      ]
    }
  ]
}

이벤트 유형 필터링

기본적으로 이벤트 원본에 대한 모든 이벤트 유형은 엔드포인트로 전송됩니다. 특정 이벤트 유형만 엔드포인트에 보내도록 결정할 수 있습니다. 예를 들어 리소스에 대한 업데이트 알림을 받을 수 있지만 삭제와 같은 다른 작업에 대한 알림을 받을 수 없습니다. 이런 경우 Microsoft.Resources.ResourceWriteSuccess 이벤트 유형별로 필터링합니다. 이벤트 유형으로 배열을 제공하거나 이벤트 원본에 대한 모든 이벤트 유형을 가져오도록 All을 지정합니다.

이벤트 유형별로 필터링에 대한 JSON 구문은 다음과 같습니다.

"filter": {
  "includedEventTypes": [
    "Microsoft.Resources.ResourceWriteFailure",
    "Microsoft.Resources.ResourceWriteSuccess"
  ]
}

제목 필터링

제목별 간단한 필터링을 위해 제목에 대한 시작 또는 끝 값을 지정합니다. 예를 들어 .txt로 끝나는 제목을 지정하여 스토리지 계정에 텍스트 파일 업로드와 관련된 이벤트만을 가져올 수 있습니다. 또는 /blobServices/default/containers/testcontainer로 시작하는 제목을 필터링하여 스토리지 계정에 다른 컨테이너가 아닌 해당 컨테이너에 대한 모든 이벤트를 가져올 수 있습니다.

사용자 지정 항목에 이벤트를 게시할 때 구독자가 이벤트에 관심이 있는지 더 쉽게 알 수 있도록 사용자 이벤트에 대한 제목을 만듭니다. 구독자는 제목 속성을 사용하여 이벤트를 필터링 및 라우팅합니다. 구독자가 해당 경로의 세그먼트를 기준으로 필터링할 수 있도록 이벤트가 발생하는 경로를 추가하는 것을 고려합니다. 구독자는 경로를 통해 이벤트를 제한적이거나 광범위하게 필터링할 수 있습니다. 제목에 /A/B/C와 같은 3개의 세그먼트 경로를 제공하는 경우 구독자는 첫 번째 세그먼트 /A를 기준으로 필터링하여 광범위한 이벤트 집합을 가져올 수 있습니다. 구독자는 /A/B/C 또는 /A/D/E와 같은 제목이 있는 이벤트를 가져옵니다. 다른 구독자는 /A/B를 기준으로 필터링하여 제한된 이벤트 집합을 얻을 수 있습니다.

예(Blob Storage 이벤트)

이벤트 유형, 컨테이너 이름 또는 생성 또는 삭제된 개체의 이름에 따라 Blob 이벤트를 필터링할 수 있습니다.

Blob Storage 이벤트의 제목은 다음 형식을 사용합니다.

/blobServices/default/containers/<containername>/blobs/<blobname>

스토리지 계정의 모든 이벤트와 일치하는 항목을 찾으려면 제목 필터를 비워 둡니다.

접두사를 공유하는 컨테이너 집합에서 생성된 Blob의 이벤트와 일치하는 항목을 찾으려면 다음과 같은 subjectBeginsWith 필터를 사용합니다.

/blobServices/default/containers/containerprefix

특정 컨테이너에서 생성된 Blob의 이벤트와 일치하는 항목을 찾으려면 다음과 같은 subjectBeginsWith 필터를 사용합니다.

/blobServices/default/containers/containername/

Blob 이름 접두사를 공유하는 특정 컨테이너에서 생성된 Blob의 이벤트와 일치하는 항목을 찾으려면 다음과 같은 subjectBeginsWith 필터를 사용합니다.

/blobServices/default/containers/containername/blobs/blobprefix

컨테이너의 특정 하위 폴더에 만들어진 Blob의 이벤트를 일치시키려면 다음과 같은 subjectBeginsWith 필터를 사용합니다.

/blobServices/default/containers/{containername}/blobs/{subfolder}/

Blob 접미사를 공유하는 특정 컨테이너에 만들어진 Blob의 이벤트와 일치시키려면 subjectEndsWith 필터(예: ".log" 또는 ".jpg")를 사용합니다.

고급 필터링

데이터 필드에서 값을 기준으로 필터링하고 비교 연산자를 지정하려면 고급 필터링 옵션을 사용합니다. 고급 필터링에서 다음을 지정합니다.

  • 연산자 형식 - 비교의 형식입니다.
  • 키 - 필터링에 사용하는 이벤트 데이터의 필드입니다. 숫자, 부울, 문자열 또는 배열일 수 있습니다.
  • 값 - 키와 비교할 값입니다.

키는 필터링에 사용하는 이벤트 데이터의 필드입니다. 다음 유형 중 하나일 수 있습니다.

  • 숫자

  • 부울

  • 문자열

  • 배열. 이 기능을 사용하려면 enableAdvancedFilteringOnArrays 속성을 true로 설정해야 합니다.

    "filter":
    {
        "subjectBeginsWith": "/blobServices/default/containers/mycontainer/blobs/log",
        "subjectEndsWith": ".jpg",
        "enableAdvancedFilteringOnArrays": true
    }
    

클라우드 이벤트 스키마의 이벤트의 경우에는 키에 eventid, source, eventtype, eventtypeversion 값 또는 이벤트 데이터(예: data.key1)를 사용합니다.

Event Grid 기본 계층을 사용하는 경우 Event Grid 스키마의 이벤트의 경우에는 키에 ID, Topic, Subject, EventType, DataVersion 값 또는 이벤트 데이터(예: data.key1)를 사용합니다. 사용자 지정 입력 스키마의 경우 이벤트 데이터 필드(예: data.key1)를 사용합니다. 데이터 섹션의 필드에 액세스하려면 .(점) 표기법을 사용합니다. 예를 들어 다음 샘플 이벤트에 대해 siteName 또는 action에 액세스하려면 data.siteName, data.appEventTypeDetail.action을 사용합니다.

	"data": {
		"appEventTypeDetail": {
			"action": "Started"
		},
		"siteName": "<site-name>",
		"clientRequestId": "None",
		"correlationRequestId": "None",
		"requestId": "292f499d-04ee-4066-994d-c2df57b99198",
		"address": "None",
		"verb": "None"
	},

참고 항목

Event Grid는 개체 배열에 대한 필터링을 지원하지 않습니다. 동일한 형식의 문자열, 부울, 숫자 및 배열(예: 정수 배열 또는 문자열 배열)만 허용됩니다.

값은 숫자, 문자열, 부울 또는 배열일 수 있습니다.

연산자

숫자에 사용 가능한 연산자는 다음과 같습니다.

NumberIn

NumberIn 연산자는 값이 지정된 필터 값 중 하나이면 true로 평가됩니다. 다음 예제에서는 data 섹션에서 counter 특성의 값이 5 또는 1인지 여부를 확인합니다.

"advancedFilters": [{
    "operatorType": "NumberIn",
    "key": "data.counter",
    "values": [
        5,
        1
    ]
}]

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: [a, b, c]의 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH filter IN (a, b, c)
    FOR_EACH key IN (v1, v2, v3)
        IF filter == key
            MATCH

NumberNotIn

NumberNotIn은 값이 지정된 필터 값이 아닐 때 true로 평가됩니다. 다음 예제에서는 data 섹션에서 counter 특성의 값이 41 및 0이 아닌지 확인합니다.

"advancedFilters": [{
    "operatorType": "NumberNotIn",
    "key": "data.counter",
    "values": [
        41,
        0
    ]
}]

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: [a, b, c]의 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH filter IN (a, b, c)
    FOR_EACH key IN (v1, v2, v3)
        IF filter == key
            FAIL_MATCH

NumberLessThan

NumberLessThan 연산자는 값이 지정된 필터 값보다 작을 때 true로 평가됩니다. 다음 예제에서는 data 섹션에서 counter 특성의 값이 100보다 작은지 여부를 확인합니다.

"advancedFilters": [{
    "operatorType": "NumberLessThan",
    "key": "data.counter",
    "value": 100
}]

키가 배열이면 배열의 모든 값이 필터에 따라 확인됩니다. 키: [v1, v2, v3]가 포함된 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH key IN (v1, v2, v3)
    IF key < filter
        MATCH

NumberGreaterThan

NumberGreaterThan 연산자는 값이 지정된 필터 값보다 클 때 true로 평가됩니다. 다음 예제에서는 data 섹션에서 counter 특성의 값이 20보다 큰지 여부를 확인합니다.

"advancedFilters": [{
    "operatorType": "NumberGreaterThan",
    "key": "data.counter",
    "value": 20
}]

키가 배열이면 배열의 모든 값이 필터에 따라 확인됩니다. 키: [v1, v2, v3]가 포함된 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH key IN (v1, v2, v3)
    IF key > filter
        MATCH

NumberLessThanOrEquals

NumberLessThanOrEquals 연산자는 값이 지정된 필터 값보다 작거나 같을 때 true로 평가됩니다. 다음 예제에서는 data 섹션에서 counter 특성의 값이 100보다 작거나 같은지 여부를 확인합니다.

"advancedFilters": [{
    "operatorType": "NumberLessThanOrEquals",
    "key": "data.counter",
    "value": 100
}]

키가 배열이면 배열의 모든 값이 필터에 따라 확인됩니다. 키: [v1, v2, v3]가 포함된 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH key IN (v1, v2, v3)
    IF key <= filter
        MATCH

NumberGreaterThanOrEquals

NumberGreaterThanOrEquals 연산자는 값이 지정된 필터 값보다 크거나 같을 때 true로 평가됩니다. 다음 예제에서는 data 섹션에서 counter 특성의 값이 30보다 크거나 같은지 여부를 확인합니다.

"advancedFilters": [{
    "operatorType": "NumberGreaterThanOrEquals",
    "key": "data.counter",
    "value": 30
}]

키가 배열이면 배열의 모든 값이 필터에 따라 확인됩니다. 키: [v1, v2, v3]가 포함된 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH key IN (v1, v2, v3)
    IF key >= filter
        MATCH

NumberInRange

NumberInRange 연산자는 값이 지정된 필터 범위 중 하나에 있으면 true로 평가됩니다. 다음 예제에서는 data 섹션에서 key1 특성의 값이 3.14159 - 999.95, 3000 - 4000의 두 범위 중 하나에 있는지 여부를 확인합니다.

{
    "operatorType": "NumberInRange",
    "key": "data.key1",
    "values": [[3.14159, 999.95], [3000, 4000]]
}

values 속성은 배열 범위입니다. 이전 예제에서는 두 범위의 배열입니다. 확인할 범위가 하나인 배열 예제는 다음과 같습니다.

범위가 하나인 배열:

{
    "operatorType": "NumberInRange",
    "key": "data.key1",
    "values": [[3000, 4000]]
}

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: 범위의 배열이 사용되는 의사 코드는 다음과 같습니다. 이 의사 코드에서 ab는 배열에 있는 각 범위의 낮은 값과 높은 값입니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH (a,b) IN filter.Values
    FOR_EACH key IN (v1, v2, v3)
       IF key >= a AND key <= b
           MATCH

NumberNotInRange

NumberNotInRange 연산자는 값이 지정된 필터 범위없으면 true로 평가됩니다. 다음 예제에서는 data 섹션에서 key1 특성의 값이 3.14159 - 999.95, 3000 - 4000의 두 범위 중 하나에 있는지 여부를 확인합니다. 범위에 있으면 연산자가 false를 반환합니다.

{
    "operatorType": "NumberNotInRange",
    "key": "data.key1",
    "values": [[3.14159, 999.95], [3000, 4000]]
}

values 속성은 배열 범위입니다. 이전 예제에서는 두 범위의 배열입니다. 확인할 범위가 하나인 배열 예제는 다음과 같습니다.

범위가 하나인 배열:

{
    "operatorType": "NumberNotInRange",
    "key": "data.key1",
    "values": [[3000, 4000]]
}

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: 범위의 배열이 사용되는 의사 코드는 다음과 같습니다. 이 의사 코드에서 ab는 배열에 있는 각 범위의 낮은 값과 높은 값입니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH (a,b) IN filter.Values
    FOR_EACH key IN (v1, v2, v3)
        IF key >= a AND key <= b
            FAIL_MATCH

부울에 사용 가능한 연산자는 다음과 같습니다.

BoolEquals

BoolEquals 연산자는 값이 지정된 부울 값 필터이면 true로 평가됩니다. 다음 예제에서는 data 섹션에서 isEnabled 특성의 값이 true인지 여부를 확인합니다.

"advancedFilters": [{
    "operatorType": "BoolEquals",
    "key": "data.isEnabled",
    "value": true
}]

키가 배열이면 배열의 모든 값이 필터 부울 값에 따라 확인됩니다. 키: [v1, v2, v3]가 포함된 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH key IN (v1, v2, v3)
    IF filter == key
        MATCH

문자열에 사용 가능한 연산자는 다음과 같습니다.

StringContains

StringContains 값에 지정된 필터 값(부분 문자열)이 포함되는 경우 true로 평가됩니다. 다음 예제에서는 data 섹션에서 key1 특성의 값이 지정된 부분 문자열 microsoft 또는 azure 중 하나를 포함하는지 여부를 확인합니다. 예를 들어 azure data factory에는 azure가 포함됩니다.

"advancedFilters": [{
    "operatorType": "StringContains",
    "key": "data.key1",
    "values": [
        "microsoft", 
        "azure"
    ]
}]

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: [a,b,c]의 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH filter IN (a, b, c)
    FOR_EACH key IN (v1, v2, v3)
        IF key CONTAINS filter
            MATCH

StringNotContains

StringNotContains 연산자는 에 지정된 필터 값이 부분 문자열로 포함되지 않는 경우 true로 평가됩니다. 키에 지정된 값 중 하나가 부분 문자열로 포함된 경우 연산자가 false로 평가됩니다. 다음 예제에서는 data 섹션에서 key1 특성의 값이 contosofabrikam을 부분 문자열로 포함하지 않는 경우에만 연산자가 true를 반환합니다.

"advancedFilters": [{
    "operatorType": "StringNotContains",
    "key": "data.key1",
    "values": [
        "contoso", 
        "fabrikam"
    ]
}]

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: [a,b,c]의 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH filter IN (a, b, c)
    FOR_EACH key IN (v1, v2, v3)
        IF key CONTAINS filter
            FAIL_MATCH

이 연산자의 현재 제한 사항에 대해서는 제한 사항 섹션을 참조하세요.

StringBeginsWith

StringBeginsWith 연산자는 값이 지정된 필터 값으로 시작하는 경우 true로 평가됩니다. 다음 예제에서는 data 섹션에서 key1 특성의 값이 event 또는 message로 시작하는지 여부를 확인합니다. 예를 들어 event hubsevent로 시작합니다.

"advancedFilters": [{
    "operatorType": "StringBeginsWith",
    "key": "data.key1",
    "values": [
        "event", 
        "message"
    ]
}]

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: [a,b,c]의 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH filter IN (a, b, c)
    FOR_EACH key IN (v1, v2, v3)
        IF key BEGINS_WITH filter
            MATCH

StringNotBeginsWith

StringNotBeginsWith 연산자는 값이 지정된 필터 값으로 시작하지 않는 경우 true로 평가됩니다. 다음 예제에서는 data 섹션에서 key1 특성의 값이 event 또는 message로 시작하지 않는지 여부를 확인합니다.

"advancedFilters": [{
    "operatorType": "StringNotBeginsWith",
    "key": "data.key1",
    "values": [
        "event", 
        "message"
    ]
}]

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: [a,b,c]의 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH filter IN (a, b, c)
    FOR_EACH key IN (v1, v2, v3)
        IF key BEGINS_WITH filter
            FAIL_MATCH

StringEndsWith

StringEndsWith 연산자는 값이 지정된 필터 값으로 끝나는 경우 true로 평가됩니다. 다음 예제에서는 data 섹션에서 key1 특성의 값이 jpg, jpeg 또는 png로 끝나는지 여부를 확인합니다. 예를 들어 eventgrid.pngpng로 끝납니다.

"advancedFilters": [{
    "operatorType": "StringEndsWith",
    "key": "data.key1",
    "values": [
        "jpg", 
        "jpeg", 
        "png"
    ]
}]

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: [a,b,c]의 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH filter IN (a, b, c)
    FOR_EACH key IN (v1, v2, v3)
        IF key ENDS_WITH filter
            MATCH

StringNotEndsWith

StringNotEndsWith 연산자는 값이 지정된 필터 값으로 끝나지 않는 경우 true로 평가됩니다. 다음 예제에서는 data 섹션에서 key1 특성의 값이 jpg, jpeg 또는 png로 끝나지 않는지 여부를 확인합니다.

"advancedFilters": [{
    "operatorType": "StringNotEndsWith",
    "key": "data.key1",
    "values": [
        "jpg", 
        "jpeg", 
        "png"
    ]
}]

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: [a,b,c]의 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH filter IN (a, b, c)
    FOR_EACH key IN (v1, v2, v3)
        IF key ENDS_WITH filter
            FAIL_MATCH

StringIn

StringIn 연산자는 값이 지정된 필터 값 중 하나와 정확히 일치하는지 여부를 확인합니다. 다음 예제에서는 data 섹션에서 key1 특성의 값이 contoso, fabrikam 또는 factory인지 여부를 확인합니다.

"advancedFilters": [{
    "operatorType": "StringIn",
    "key": "data.key1",
    "values": [
        "contoso", 
        "fabrikam", 
        "factory"
    ]
}]

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: [a,b,c]의 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH filter IN (a, b, c)
    FOR_EACH key IN (v1, v2, v3)
        IF filter == key
            MATCH

StringNotIn

StringNotIn 연산자는 값이 지정된 필터 값과 일치하지 않는지 여부를 확인합니다. 다음 예제에서는 data 섹션에서 key1 특성의 값이 awsbridge가 아닌지 확인합니다.

"advancedFilters": [{
    "operatorType": "StringNotIn",
    "key": "data.key1",
    "values": [
        "aws", 
        "bridge"
    ]
}]

키가 배열이면 배열의 모든 값이 필터 값의 배열에 따라 확인됩니다. 키: [v1, v2, v3] 및 필터: [a,b,c]의 의사 코드는 다음과 같습니다. 필터의 데이터 형식과 일치하지 않는 데이터 형식의 키 값은 무시됩니다.

FOR_EACH filter IN (a, b, c)
    FOR_EACH key IN (v1, v2, v3)
        IF filter == key
            FAIL_MATCH

모든 문자열 비교는 대/소문자를 구분합니다.

참고 항목

이벤트 JSON에 고급 필터 키가 포함되지 않은 경우 필터가 NumberGreaterThan, NumberGreaterThanOrEquals, NumberLessThan, NumberLessThanOrEquals, NumberIn, BoolEquals, StringContains, StringNotContains, StringBeginsWith, StringNotBeginsWith, StringEndsWith, StringNotEndsWith, StringIn 연산자에 대해 일치하지 않음으로 평가됩니다.

이 필터는 NumberNotIn, StringNotIn 연산자에 대해 일치함으로 평가됩니다.

IsNullOrUndefined

IsNullOrUndefined 연산자는 키 값이 NULL 또는 정의되지 않은 경우 true로 평가됩니다.

{
    "operatorType": "IsNullOrUndefined",
    "key": "data.key1"
}

다음 예제에서는 key1이 누락되었으므로 연산자가 true로 평가됩니다.

{ 
    "data": 
    { 
        "key2": 5 
    } 
}

다음 예제에서 key1은 null로 설정되므로 연산자가 true로 평가됩니다.

{
    "data": 
    { 
        "key1": null
    }
}

이 예제에서 key1에 다른 값이 있으면 연산자가 false로 평가됩니다.

IsNotNull

IsNotNull 연산자는 키의 값이 NULL이 아니거나 정의되지 않았으면 true로 평가됩니다.

{
    "operatorType": "IsNotNull",
    "key": "data.key1"
}

OR 및 AND

여러 값으로 단일 필터를 지정하면 OR 연산이 수행됩니다. 따라서 키 필드의 값이 해당 값 중 하나여야 합니다. 예를 들면 다음과 같습니다.

"advancedFilters": [
    {
        "operatorType": "StringContains",
        "key": "Subject",
        "values": [
            "/providers/microsoft.devtestlab/",
            "/providers/Microsoft.Compute/virtualMachines/"
        ]
    }
]

다른 여러 필터를 지정하는 경우 AND 연산이 수행됩니다. 따라서 각 필터 조건이 충족되어야 합니다. 예를 들면 다음과 같습니다.

"advancedFilters": [
    {
        "operatorType": "StringContains",
        "key": "Subject",
        "values": [
            "/providers/microsoft.devtestlab/"
        ]
    },
    {
        "operatorType": "StringContains",
        "key": "Subject",
        "values": [
            "/providers/Microsoft.Compute/virtualMachines/"
        ]
    }
]

CloudEvents

CloudEvents 스키마에 있는 이벤트의 경우 키에 eventid, source, eventtype, eventtypeversion 값 또는 이벤트 데이터(예: data.key1)를 사용합니다.

CloudEvents 1.0에서 확장 컨텍스트 특성을 사용할 수도 있습니다. 다음 예제에서 comexampleextension1comexampleothervalue는 확장 컨텍스트 특성입니다.

{
    "specversion" : "1.0",
    "type" : "com.example.someevent",
    "source" : "/mycontext",
    "id" : "C234-1234-1234",
    "time" : "2018-04-05T17:31:00Z",
    "subject": null,
    "comexampleextension1" : "value",
    "comexampleothervalue" : 5,
    "datacontenttype" : "application/json",
    "data" : {
        "appinfoA" : "abc",
        "appinfoB" : 123,
        "appinfoC" : true
    }
}

다음은 필터에서 확장 컨텍스트 특성을 사용하는 예제입니다.

"advancedFilters": [{
    "operatorType": "StringBeginsWith",
    "key": "comexampleothervalue",
    "values": [
        "5", 
        "1"
    ]
}]

제한 사항

고급 필터링에는 다음과 같은 제한이 있습니다.

  • Event Grid 구독당 모든 필터 값이 고급 필터 25개 및 필터 25개로 제한됨
  • 문자열 값당 512자
  • .(점) 문자가 포함된 키. 예를 들어 http://schemas.microsoft.com/claims/authnclassreference 또는 john.doe@contoso.com입니다. 현재까지는 키에서 이스케이프 문자가 지원되지 않습니다.

둘 이상의 필터에 동일한 키를 사용할 수 있습니다.

다음 단계