翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。
Step Functions を使用して Amazon ECSまたは Fargate タスクを実行する
Step Functions を Amazon ECSまたは Fargate と統合してタスクを実行および管理する方法を説明します。Amazon ではECS、タスクは計算の基本単位です。タスクは、コンテナイメージ、CPUメモリ制限、ネットワーク設定、その他のパラメータなど、Docker コンテナの実行方法を指定するタスク定義によって定義されます。このページでは、使用可能な Amazon ECSAPIアクションを一覧表示し、Step Functions を使用して Amazon ECSタスクにデータを渡す方法の手順を示します。
Step Functions での AWS サービスとの統合については、 サービスとの統合「」および「」を参照してくださいStep Functions APIのサービスへのパラメータの受け渡し。
最適化された Amazon ECS/Fargate 統合の主な機能
-
ジョブの実行 (.sync) 統合パターンがサポートされています。
ecs:runTask
は 200 HTTP レスポンスを返すことができますが、次のように空でないFailures
フィールドがあります。[リクエストレスポンス]: レスポンスを返し、タスクは失敗しません。これは、最適化なしと同じです。
[ジョブを実行する]: 空でない
Failures
フィールドが検出された場合、AmazonECS.Unknown
エラーが発生し、タスクは失敗します。
サポートされている Amazon ECS/Fargate APIs
-
RunTask
は、指定されたタスク定義を使用して新しいタスクを開始します。
のパラメータ Step Functions は で表されます PascalCase
API アクション camelCaseなどのネイティブサービスAPIが にある場合でもstartSyncExecution
、 PascalCaseなどのパラメータを で指定しますStateMachineArn
。
Amazon ECSタスクにデータを渡す
Step Functions での AWS サービスとの統合については、 サービスとの統合「」および「」を参照してくださいStep Functions APIのサービスへのパラメータの受け渡し。
overrides
を使用してコンテナのデフォルトコマンドを上書きし、Amazon ECSタスクに入力を渡すことができます。「ContainerOverride
」を参照してください。この例では、 JsonPath を使用して、入力Task
から Task
状態に値を渡しています。
以下には、Amazon ECSタスクを実行し、完了するまで待機する Task
状態が含まれています。
{
"StartAt": "Run an ECS Task and wait for it to complete",
"States": {
"Run an ECS Task and wait for it to complete": {
"Type": "Task",
"Resource": "arn:aws:states:::ecs:runTask.sync",
"Parameters": {
"Cluster": "cluster-arn
",
"TaskDefinition": "job-id
",
"Overrides": {
"ContainerOverrides": [
{
"Name": "container-name
",
"Command.$": "$.commands"
}
]
}
},
"End": true
}
}
}
ContainerOverrides
の "Command.$": "$.commands"
行は状態の入力からコンテナにコマンドを渡します。
前の例では、実行への入力が次の場合、各コマンドはコンテナのオーバーライドとして渡されます。
{
"commands": [
"test command 1",
"test command 2",
"test command 3"
]
}
以下には、Amazon ECSタスクを実行し、タスクトークンが返されるまで待機する Task
状態が含まれています。「タスクトークンのコールバックまで待機する」を参照してください。
{
"StartAt":"Manage ECS task",
"States":{
"Manage ECS task":{
"Type":"Task",
"Resource":"arn:aws:states:::ecs:runTask.waitForTaskToken",
"Parameters":{
"LaunchType":"FARGATE",
"Cluster":"cluster-arn
",
"TaskDefinition":"job-id
",
"Overrides":{
"ContainerOverrides":[
{
"Name":"container-name
",
"Environment":[
{
"Name":"TASK_TOKEN_ENV_VARIABLE",
"Value.$":"$$.Task.Token"
}
]
}
]
}
},
"End":true
}
}
}
IAM Amazon ECS/ を呼び出すための ポリシーAWS Fargate
次のサンプルテンプレートは、 がステートマシン定義のリソースに基づいてIAMポリシー AWS Step Functions を生成する方法を示しています。詳細については、Step Functions が統合サービスの IAM ポリシーを生成する方法およびStep Functions でサービス統合パターンを検出するを参照してください。
TaskId
の値は、タスクが送信されるまで不明なため、Step Functions は、権限の高い "Resource": "*"
ポリシーを作成します。
注記
"*"
IAM ポリシーにかかわらず、Step Functions によって開始された Amazon Elastic Container Service (Amazon ECS) タスクのみを停止できます。
スケジュールされた Amazon ECSタスクでタスク実行ロール、タスクロール、またはタスクロールオーバーライドを使用する必要がある場合は、各タスク実行ロール、タスクロール、またはタスクロールオーバーライドのiam:PassRole
アクセス許可を、呼び出し元のエンティティの CloudWatch イベントIAMロールに追加する必要があります。この場合は Step Functions です。