翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。
部分的なバッチレスポンス実装のベストプラクティス
このセクションでは、Amazon SQS イベントソースの部分的なバッチレスポンスを設定するためのベストプラクティスについて説明します。
-
デッドレターキューを設定して、サーバーレスアプリケーションのアーキテクチャにスノーボールアンチパターンが発生するのを防ぎます。詳細については「スノーボールアンチパターンの回避」セクションを参照してください。
-
失敗したメッセージのみを表示するように Lambda 関数イベントソースマッピングを設定します。これを行うには、イベントソースマッピングを設定するときにReportBatchItemFailures を FunctionResponseTypes リストに追加します。Lambda 関数は、SQS によって呼び出されると、部分的なバッチレスポンスを実装する必要があります。Powertools for AWS Lambda Batch Processing ユーティリティの使用を検討してください。このユーティリティは、部分バッチサポートが組み込まれた SQS メッセージを処理します。
Batch 処理
-
SQS によって呼び出される Lambda 関数に部分的なバッチレスポンスを実装します。Powertools for AWS Lambda Batch Processing ユーティリティの使用を検討してください。このユーティリティは、部分的なバッチレスポンスのサポートが組み込まれた SQS メッセージ処理を処理します。詳細については、「 AWS Lambda デベロッパーガイド」のAmazon SQSトリガーを使用した Lambda 関数のバッチ項目障害の報告」を参照してください。
AWS Lambda バッチ処理ユーティリティの Powertools
べき等性
-
メッセージがデッドレターキューに移動する前にソースキューに送信される回数を定義します。最も可能性の高い障害の原因とその推定復旧時間を特定して、定義した値がアプリケーションのユースケースに適合していることを確認します。再試行回数を定義するには、ソースキューの RedrivePolicy で maxReceiveCount 値を設定します。詳細については、「Amazon SQS API リファレンス」の「SetQueueAttributes」を参照してください。また、「Amazon Simple Queue Service デッドレターキューリドライブをソースキューに導入する
」を参照してください。 -
Lambda コードがべき等であり、メッセージを複数回処理できることを確認します。べき等性を実装するには、Powertools for AWS Lambda Idempotency Utility の使用を検討してください。これにより、Amazon SQS バッチ内の個々のジョブをサポートする関数のコードが準備されます。まず、ReportBatchItemFailures をイベントソースマッピングに組み込みます。詳細については、「 AWS Lambda デベロッパーガイド」の「部分的なバッチレスポンスの実装」およびAmazon SQSメッセージが Lambda 関数を複数回呼び出すのを防ぐにはどうすればよいですか?」を参照してください。
Powertools for AWS Lambda Idempotency ユーティリティ
メトリクス
-
ジョブの詳細と失敗したジョブを追跡するために 関数にビジネスメトリクスを組み込むには、aws-embedded-metrics または Powertools for AWS Lambda Metrics Utility を使用することを検討してください。これにより、埋め込みメトリクス形式で SQS イベントを処理しながら運用メトリクスとビジネスメトリクスが出力されます。
AWS Lambda メトリクスユーティリティの Powertools
-
FirstFirst-In-First-Out (FIFO) キューを使用する場合、関数は最初の失敗後にメッセージの処理を停止し、失敗したメッセージと未処理のメッセージをすべて batchItemFailures で返す必要があります。これにより、キューのメッセージ順序が保持されます。
注記
部分バッチ処理を使用するアプリケーションの全体的なパフォーマンスを追跡するには、コードレベルのパフォーマンス追跡が必要です。バッチ処理が設定されると、Lambda 関数の呼び出しは通常、処理結果に関係なく成功します。
スノーボールアンチパターンの回避
Lambda と Amazon SQS は、アップストリームマイクロサービスが SQS キューに書き込むメッセージを制御できません。処理できないメッセージがある場合、Lambda は別のデッドレターキューが設定されていない限り、未処理のメッセージをソース SQS キューに返します。その後、未処理のメッセージは Lambda 関数によって再試行されます。デッドレターキューが存在しない場合、Amazon SQS キューに返される未処理のメッセージの数は、最終的にキューの有効なメッセージを上回ります。
このタイプの Snowball アンチパターンは、連続する各 Lambda 呼び出しが問題を悪化させるため、次の問題を引き起こす可能性があります。
-
ジョブの処理に通常よりも時間がかかるか、まったく処理されないため、ユーザーエクスペリエンスが悪い
-
Amazon SQS キュー内のメッセージ数とメッセージ再試行回数の急激な増加に比例するコストの増加
-
アプリケーションの Lambda コンピューティング容量の削減、または AWS アカウント関数の呼び出しリクエストに制限がない場合
部分的なバッチレスポンスを設定するときに Snowball アンチパターンを作成しないようにするには、デッドレターキューも作成することをお勧めします。この個別のキューに正常に処理されなかったメッセージを格納できるため、アプリケーションの未処理メッセージのライフサイクルをより適切に管理できます。
詳細については、Amazon SQS デベロッパーガイド」の「Amazon SQS コンソールを使用してデッドレターキューを設定する」を参照してください。 Amazon SQS