本文為英文版的機器翻譯版本,如內容有任何歧義或不一致之處,概以英文版為準。
對於事件封存和分析,Amazon SNS 現在建議使用其與 Amazon Data Firehose 的原生整合。您可以訂閱 Firehose 交付串流至 SNS 主題,這可讓您將通知傳送至封存和分析端點,例如 Amazon Simple Storage Service (Amazon S3) 儲存貯體、Amazon Redshift 資料表、Amazon OpenSearch Service (OpenSearch Service) 等。搭配使用 Amazon SNS 與 Firehose 交付串流是完全受管且無程式碼的解決方案,不需要您使用 AWS Lambda 函數。如需詳細資訊,請參閱Fanout to Firehose 交付串流。 |
本教學課程說明如何部署事件儲存和備份管道,並讓管道訂閱 Amazon SNS 主題。此程序會自動將與管道相關聯的 AWS SAM 範本轉換為 AWS CloudFormation 堆疊,然後將堆疊部署到您的 AWS 帳戶。此程序還會建立和設定一組資源 (構成事件儲存和備份管道),包括下列項目:
-
Amazon SQS 佇列
-
Lambda 函數
-
Firehose 交付串流
-
Amazon S3 備份儲存貯體
如需使用 Amazon S3 儲存貯體做為目的地設定串流的詳細資訊,請參閱《Amazon Data Firehose API 參考S3DestinationConfiguration
》中的 。
如需有關轉換事件和設定事件緩衝、事件壓縮和事件加密的詳細資訊,請參閱《Amazon Data Firehose 開發人員指南》中的建立 Amazon Data Firehose 交付串流。
如需有關篩選事件的詳細資訊,請參閱本指南中的Amazon SNS 訂閱篩選政策。
-
登入 AWS Lambda 主控台
。 -
在導覽面板上,選擇 Functions (函數),然後選擇 Create function (建立函數)。
-
在 Create function (建立函數) 頁面上,執行下列動作:
-
選擇瀏覽無伺服器應用程式存放庫、公有應用程式、顯示建立自訂 IAM 角色或資源政策的應用程式。
-
搜尋
fork-event-storage-backup-pipeline
,然後選擇應用程式。
-
-
在 fork-event-storage-backup-pipeline 頁面上,執行下列動作:
-
在 Application settings (應用程式設定) 區段中,輸入 Application name (應用程式名稱) (例如,
my-app-backup
)。注意
-
對於每個部署,應用程式名稱必須是唯一的。如果您重複使用應用程式名稱,部署只會更新先前部署的 AWS CloudFormation 堆疊 (而不是建立新的堆疊)。
-
-
(選用) 針對 BucketArn,輸入要載入傳入事件之 Amazon S3 儲存貯體的 ARN。如果您未輸入值,則會在 AWS 帳戶中建立新的 Amazon S3 儲存貯體。
-
(選用) 對於 DataTransformationFunctionArn,輸入 Lambda 函數的 ARN,以透過此函數來轉換傳入的事件。如果您不輸入值,資料轉換會停用。
-
(選用) 輸入下列其中之一 LogLevel 設置來執行應用程序的 Lambda 函數:
-
DEBUG
-
ERROR
-
INFO
(default) -
WARNING
-
-
對於 TopicArn,輸入 Amazon SNS 主題的 ARN,表示分支管道的此執行個體將訂閱此主題。
-
(選用) 對於 StreamBufferingIntervalInSeconds 和 StreamBufferingSizeInMBs,輸入值來設定如何緩衝傳入的事件。如果您不輸入任何值,則會使用 300 秒和 5 MB。
-
(選用) 輸入以下其中一個 StreamCompressionFormat 設定來壓縮傳入的事件:
-
GZIP
-
SNAPPY
-
UNCOMPRESSED
(default) -
ZIP
-
-
(選用) 對於 StreamPrefix,輸入字串字首,以命名存放在 Amazon S3 備份儲存貯體中的檔案。如果您不輸入值,則不會使用字首。
-
(選用) 對於 SubscriptionFilterPolicy,使用 JSON 格式輸入 Amazon SNS 訂閱篩選政策,以用於篩選傳入的事件。篩選政策決定哪些事件會在 OpenSearch Service 索引中編製索引。如果您不輸入值,則不會使用篩選 (所有事件都編製索引)。
-
(可選) 針對 SubscriptionFilterPolicyScope,請輸入字串
MessageBody
或MessageAttributes
,啟用以承載或屬性為基礎的訊息篩選。 -
選擇 I acknowledge that this app creates custom IAM roles, resource policies and deploys nested applications. (我了解此應用程式會建立自訂 IAM 角色、資源政策及部署巢狀應用程式。),然後選擇 Deploy (部署)。
-
在部署狀態my-app
頁面上,Lambda 會顯示您的應用程式正在部署狀態。
在資源區段中, AWS CloudFormation 開始建立堆疊,並顯示每個資源的 CREATE_IN_PROGRESS 狀態。程序完成時, AWS CloudFormation 會顯示 CREATE_COMPLETE 狀態。
當部署完成時,Lambda 會顯示 Your application has been deployed (您的應用程式已經完成部署) 狀態。
發佈至 Amazon SNS 主題的訊息會自動存放在由事件儲存和備份管道佈建的 Amazon S3 備份儲存貯體中。