Amazon S3 バケットのデータを分散マップで処理する
このサンプルプロジェクトでは、分散マップ状態を使用して大規模なデータを処理する方法を示します。例えば、過去の気象データを分析し、地球上で毎月の平均気温が最も高い気象観測所を特定します。気象データは 12,000 を超える CSV ファイルに記録され、Amazon S3 バケットに保存されています。
このサンプルプロジェクトには、[分散 S3 コピー NOA データ] と [ProcessNOAAData] という名前の 2 つの分散マップ状態が含まれています。[分散 S3 コピー NOA データ] は、[noaa-gsod-pds] という名前のパブリック Amazon S3 バケット内の CSV ファイルを繰り返し処理し、それらを AWS アカウント の Amazon S3 バケットにコピーします。[ProcessNOAAData] はコピーされたファイルを繰り返し処理し、温度分析を実行する Lambda 関数を含めます。
サンプルプロジェクトでは、まず ListObjectsV2 API アクションを呼び出して Amazon S3 バケットの内容を確認します。この呼び出しに応答して返されたキーの数に基づいて、サンプルプロジェクトでは以下のいずれかの判断を行います。
-
キー数が 1 以上の場合、プロジェクトは [ProcessNOAAData] ステートに移行します。この分散マップ状態には、毎月の平均気温が最も高い気象観測所を検索する [TemperatureFunction] という名前の Lambda 関数が含まれています。この関数は、キーとして
year-monthを含む辞書と、値として気象観測所に関する情報を含む辞書を返します。 -
返されるキー数が 1 を超えない場合、[Distributed S3 コピーの NOA データ] ステートにはパブリックバケット [noaa-gsod-pds] のすべてのオブジェクトが一覧表示され、個々のオブジェクトはアカウント内の別のバケットに 100 件ずつ繰り返しコピーされます。インラインマップはオブジェクトの反復コピーを実行します。
すべてのオブジェクトがコピーされると、プロジェクトは [ProcessNOAAData] ステートに移行して気象データを処理します。
サンプルプロジェクトは最終的にリデューサー Lambda 関数に移行します。リデューサー関数は [TemperatureFunction] 関数によって返された結果を最終的に集計し、結果を Amazon DynamoDB テーブルに書き込みます。
分散マップを使用すると、同時に最大 10,000 件の子ワークフローを並列実行できます。このサンプルプロジェクトでは、[ProcessNOAAData] 分散マップの最大同時実行数は 3000 件に設定されており、子ワークフローの並列実行数は 3000 件に制限されています。
このサンプルプロジェクトは、ステートマシン、サポートする AWS リソースを作成し、関連する IAM アクセス許可を構成します。このサンプルプロジェクトについて調べ、分散マップを使用して大規模な並列ワークロードをオーケストレーションしたり、独自のプロジェクトの出発点として使用したりする方法について説明します。
重要
このサンプルプロジェクトは米国東部 (バージニア北部) リージョン限定で利用できます。
ステップ 1: ステートマシンを作成する
-
Step Functions コンソール
を開き、[ステートマシンの作成] を選択します。 -
[テンプレートから作成] を選択し、関連するスターターテンプレートを見つけます。[次へ] を選択して続行します。
-
テンプレートの使用方法を選択します。
-
デモの実行 – 読み取り専用のステートマシンを作成します。確認後、ワークフローとすべての関連リソースを作成できます。
-
その上に構築する – 編集可能なワークフロー定義が提供され、内容を確認・カスタマイズし、独自のリソースでデプロイできます (関数やキューなどの関連リソースは自動的には作成されません)。
-
-
[テンプレートの使用] を選択して選択を続行します。
注記
アカウントにデプロイされたサービスには、Standard 料金が適用されます。
ステップ 2: デモステートマシンを実行する
[デモの実行] オプションを選択した場合、すべての関連リソースがデプロイされ、実行準備が整います。[その上に構築する] オプションを選択した場合は、プレースホルダー値の設定や、カスタムワークフローの実行に必要な追加リソースの作成が必要になることがあります。
[Deploy and run] (デプロイと実行) を選択します。
CloudFormation スタックがデプロイされるのを待ちます。これには最大 10 分かかることがあります。
[実行を開始] オプションが表示されたら、[入力] を確認し、[実行を開始] を選択します。
お疲れ様でした。
これで、ステートマシンのデモが実行されます。グラフビューでステートを選択すると、入力、出力、変数、定義、イベントを確認できます。