Eventarc 觸發條件會宣告您對特定事件或一組事件感興趣,讓您擷取並對特定事件採取行動。當系統建立符合觸發條件的稽核記錄時,Eventarc 會透過 type=google.cloud.audit.log.v1.written
將要求傳送至目的地。系統會根據稽核記錄項目中的下列值進行比對:
serviceName
:寫入稽核記錄的服務methodName
:稽核的作業resourceName
:要稽核的資源
如需 Google Cloud 提供稽核記錄的服務清單,請參閱Google Cloud 含有稽核記錄的服務。您也可以擷取適用於 google.cloud.audit.log.v1.written
事件類型的事件篩選器值。
找出事件篩選器
如要找出建立觸發條件所需的確切事件篩選器,請產生要擷取的事件,然後查看對應的 Cloud 稽核記錄項目。請注意,記錄項目中的資料可能會分散在多個項目中。
請確認您已為服務啟用資料存取稽核記錄類型。
請注意,預設啟用稽核功能的服務不會列入清單。
在「Audit Logs」頁面的主要表格中,選取 Google Cloud服務。
在「記錄類型」分頁中,選取「管理員讀取」、「資料讀取」和「資料寫入」核取方塊,然後按一下「儲存」。
執行要建立事件篩選器的作業,並產生稽核記錄項目。例如,將檔案儲存在 Cloud Storage 值區中。
前往 Google Cloud 控制台的「Logs Explorer」。
在「查詢建立工具」窗格中,建構並執行查詢,以便篩選記錄項目並擷取結果。例如:
resource.type="gcs_bucket" resource.labels.bucket_name="eventarc-bucket"
如要進一步瞭解如何建構查詢來擷取及修正記錄檔,請參閱「使用 Logging 查詢語言建構查詢」。
如要查看單一記錄項目的完整詳細資料,請按一下項目開頭的展開箭頭 (▸)。
protoPayload
欄位可區分稽核記錄項目與其他記錄項目。在下列範例中,我們省略了記錄項目的某些部分,並將某些欄位醒目顯示:{ protoPayload:{ @type:"type.googleapis.com/google.cloud.audit.AuditLog", status:{}, authenticationInfo:{}, requestMetadata:{}, serviceName:"storage.googleapis.com", methodName:"storage.objects.create", authorizationInfo:[], resourceName:"projects/_/buckets/eventarc-bucket/objects/random.txt", resourceLocation:{} }, insertId:"il9evleafpdk", resource:{ type:"gcs_bucket", labels:{ project_id:"cloud-run-test", location:"us-central1", bucket_name:"eventarc-bucket" } }, timestamp:"2021-03-05T15:55:20.754688805Z", severity:"INFO", logName:"projects/cloud-run-test/logs/cloudaudit.googleapis.com%2Fdata_access", receiveTimestamp:"2021-03-05T15:55:20.884984611Z" }
您可以使用下列資訊驗證這項稽核記錄項目的內容:
protoPayload.@type
欄位為type.googleapis.com/google.cloud.audit.AuditLog
。logName
欄位包含網域cloudaudit.googleapis.com
。
protoPayload.serviceName
欄位是寫入稽核記錄的服務。protoPayload.methodName
欄位是稽核的作業。protoPayload.resourceName
欄位是指要稽核的資源。
如要進一步瞭解如何在稽核記錄項目中找出資訊,請參閱「瞭解稽核記錄」。
擷取事件篩選器值
您可以使用 gcloud eventarc audit-logs-provider
指令,探索並列出 google.cloud.audit.log.v1.written
事件類型的提供者 serviceName
和 methodName
值。
如要列出服務名稱,請執行下列指令:
gcloud eventarc audit-logs-provider service-names list
這會傳回 google.cloud.audit.log.v1.written
事件類型的所有 serviceName
屬性值。
如要列出特定服務的方法名稱,請執行下列指令:
gcloud eventarc audit-logs-provider method-names list \ --service-name=SERVICE_NAME
將 SERVICE_NAME
替換為 serviceName
值,例如 bigquery.googleapis.com
。
Eventarc 觸發條件範例
以下範例會為 Workflows 目的地建立名為 cal-workflows-trigger
的觸發條件。針對由 bigquery.googleapis.com
寫入的稽核記錄,以及標示為 google.cloud.bigquery.v2.JobService.InsertJob
的作業,觸發稽核記錄篩選器:
gcloud eventarc triggers create cal-workflows-trigger \ --location=us-central1 \ --destination-workflow=my-workflow \ --destination-workflow-location=europe-west4 \ --event-filters="type=google.cloud.audit.log.v1.written" \ --event-filters="serviceName=bigquery.googleapis.com" \ --event-filters="methodName=google.cloud.bigquery.v2.JobService.InsertJob" \ --service-account=${TRIGGER_SA}@${PROJECT_ID}.iam.gserviceaccount.com
以下範例會為 Cloud Run 目的地建立名為 cal-run-trigger
的觸發條件。針對由 workflows.googleapis.com
寫入的稽核記錄,以及標示為 google.cloud.workflows.v1.Workflows.GetWorkflow
的作業,觸發稽核記錄篩選器:
gcloud eventarc triggers create cal-run-trigger \ --location=us-central1 \ --destination-run-service=helloworld-events \ --destination-run-region=us-central1 \ --event-filters="type=google.cloud.audit.log.v1.written" \ --event-filters="serviceName=workflows.googleapis.com" \ --event-filters="methodName=google.cloud.workflows.v1.Workflows.GetWorkflow" \ --event-filters="resourceName=projects/_/locations/us-central1/workflows/test-workflow" \ --service-account=${PROJECT_NUMBER}-compute@developer.gserviceaccount.com
稽核記錄項目過大
Cloud Logging 會將超過使用限制的稽核記錄項目分割,並將原始稽核記錄項目中的資料分散到多個分割項目中。如果記錄項目包含 split
欄位,則該項目是將較大的原始記錄項目分割的結果。split
欄位是 LogSplit
物件,其中包含用來識別相關分割項目所需的資訊。
每個分割項目都有一個 protoPayload
,其中包含相同的 serviceName
、methodName
和 resourceName
值,可協助篩選 Cloud Audit Logs 事件。Eventarc 觸發條件會為每個分割項目提供事件。
如果稽核記錄項目會分割為多個記錄項目,您可以篩選 LogEntry
中的任何欄位。舉例來說,如果您需要一系列分割記錄項目中的首個項目,可以執行下列 gcloud CLI 指令,並使用 split.index=0
表示首個項目的位置:
gcloud logging read "split.index=0"
如需詳細資訊 (包括如何辨識項目和查詢範例),請參閱「分割稽核記錄項目」。