使用 AWS CloudTrail 來監控 Amazon OpenSearch Service API 呼叫 - Amazon OpenSearch Service

使用 AWS CloudTrail 來監控 Amazon OpenSearch Service API 呼叫

Amazon OpenSearch Service 已與 AWS CloudTrail 整合,這項服務可提供由使用者、角色或 OpenSearch Service 中的 AWS 服務所採取之動作的記錄。CloudTrail 會擷取 OpenSearch Service 的所有組態 API 呼叫作為事件。

注意

CloudTrail 只會擷取對組態 API 的呼叫,例如 CreateDomainGetUpgradeStatus。CloudTrail 不會擷取對 OpenSearch API 的呼叫,例如 _search_bulk。對於這些呼叫,請參閱在 Amazon OpenSearch Service 中監控稽核日誌

擷取的呼叫包括來自 OpenSearch Service 主控台、AWS CLI 或 AWS 開發套件的呼叫。如果您建立追蹤,就可以將 CloudTrail 事件持續交付到 Amazon S3 儲存貯體,包括 OpenSearch Service 的事件。即使您未設定追蹤,依然可以透過 CloudTrail 主控台中的 Event history (事件歷史記錄) 檢視最新事件。您可以利用 CloudTrail 所收集的資訊來判斷向 OpenSearch Service 發出的請求,以及發出請求的 IP 地址、人員、時間和其他詳細資訊。

若要進一步了解 CloudTrail,請參閱 AWS CloudTrail 使用者指南

CloudTrail 中的 Amazon OpenSearch Service 資訊

當您建立帳戶時,系統即會在 AWS 帳戶 中啟用 CloudTrail。當活動發生於 OpenSearch Service 中時,系統便會將該活動記錄在 CloudTrail 事件中,並將其他 AWS 服務事件記錄在 Event history (事件歷史) 中。您可以檢視、搜尋和下載 AWS 帳戶 帳戶的最新事件。如需詳細資訊,請參閱使用 CloudTrail 事件歷史記錄檢視事件

對於您 AWS 帳戶 帳戶中正在進行的事件記錄 (包含 OpenSearch Service 的事件),請建立追蹤。追蹤能讓 CloudTrail 將日誌檔交付至 Amazon S3 儲存貯體。依預設,當您在主控台中建立追蹤時,該追蹤會套用至所有的 AWS 區域。該追蹤會記錄來自 AWS 分割區中所有區域的事件,並將日誌檔案交付到您指定的 Amazon S3 儲存貯體。此外,您可以設定其他 AWS 服務,以進一步分析和處理 CloudTrail 日誌中所收集的事件資料。如需詳細資訊,請參閱下列內容:

CloudTrail 會記錄所有 OpenSearch Service 組態 API 動作,並會記錄在 Amazon OpenSearch Service 的組態 API 參考 中。

每一筆事件或日誌項目都會包含產生請求者的資訊。身分資訊可協助您判斷下列事項:

  • 該請求是否使用根或 AWS Identity and Access Management (IAM) 使用者登入資料提出

  • 提出該請求時,是否使用了特定角色或聯合身分使用者的暫時安全登入資料

  • 該請求是否由另一項 AWS 服務提出

如需詳細資訊,請參閱 CloudTrail userIdentity 元素

了解 Amazon OpenSearch Service 日誌檔案項目

追蹤是一種組態,能讓事件以日誌檔案的形式交付到您指定的 Amazon S3 儲存貯體。CloudTrail 日誌檔包含一或多個日誌項目。一個事件為任何來源提出的單一請求,並包含請求動作、請求的日期和時間、請求參數等資訊。CloudTrail 日誌檔並非依公有 API 呼叫的堆疊追蹤排序,因此不會以任何特定順序出現。

以下範例顯示的 CloudTrail 日誌項目會示範 CreateDomain 操作:

{ "eventVersion": "1.05", "userIdentity": { "type": "IAMUser", "principalId": "AIDACKCEVSQ6C2EXAMPLE", "arn": "arn:aws:iam::123456789012:user/test-user", "accountId": "123456789012", "accessKeyId": "access-key", "userName": "test-user", "sessionContext": { "attributes": { "mfaAuthenticated": "false", "creationDate": "2018-08-21T21:59:11Z" } }, "invokedBy": "signin.amazonaws.com" }, "eventTime": "2018-08-21T22:00:05Z", "eventSource": "es.amazonaws.com", "eventName": "CreateDomain", "awsRegion": "us-west-1", "sourceIPAddress": "123.123.123.123", "userAgent": "signin.amazonaws.com", "requestParameters": { "engineVersion": "OpenSearch_1.0", "clusterConfig": { "instanceType": "m4.large.search", "instanceCount": 1 }, "snapshotOptions": { "automatedSnapshotStartHour": 0 }, "domainName": "test-domain", "encryptionAtRestOptions": {}, "eBSOptions": { "eBSEnabled": true, "volumeSize": 10, "volumeType": "gp2" }, "accessPolicies": "{\"Version\":\"2012-10-17\",\"Statement\":[{\"Effect\":\"Allow\",\"Principal\":{\"AWS\":[\"123456789012\"]},\"Action\":[\"es:*\"],\"Resource\":\"arn:aws:es:us-west-1:123456789012:domain/test-domain/*\"}]}", "advancedOptions": { "rest.action.multi.allow_explicit_index": "true" } }, "responseElements": { "domainStatus": { "created": true, "clusterConfig": { "zoneAwarenessEnabled": false, "instanceType": "m4.large.search", "dedicatedMasterEnabled": false, "instanceCount": 1 }, "cognitoOptions": { "enabled": false }, "encryptionAtRestOptions": { "enabled": false }, "advancedOptions": { "rest.action.multi.allow_explicit_index": "true" }, "upgradeProcessing": false, "snapshotOptions": { "automatedSnapshotStartHour": 0 }, "eBSOptions": { "eBSEnabled": true, "volumeSize": 10, "volumeType": "gp2" }, "engineVersion": "OpenSearch_1.0", "processing": true, "aRN": "arn:aws:es:us-west-1:123456789012:domain/test-domain", "domainId": "123456789012/test-domain", "deleted": false, "domainName": "test-domain", "accessPolicies": "{\"Version\":\"2012-10-17\",\"Statement\":[{\"Effect\":\"Allow\",\"Principal\":{\"AWS\":\"arn:aws:iam::123456789012:root\"},\"Action\":\"es:*\",\"Resource\":\"arn:aws:es:us-west-1:123456789012:domain/test-domain/*\"}]}" } }, "requestID": "12345678-1234-1234-1234-987654321098", "eventID": "87654321-4321-4321-4321-987654321098", "eventType": "AwsApiCall", "recipientAccountId": "123456789012" }