AWS StepFunction-无法更新状态机

时间:2019-07-18 14:25:03

标签: aws-step-functions

我有一台工作正常的StepFunction状态机,其中有4个步骤触发了4个Lambda。

由于其中一个步骤将是运行时间更长的任务,因此我决定将其中一个Lambda转变为Fargate任务。

配置ECS和Fargate任务后,我尝试更新状态机定义,但收到错误:Failed to update state machine.,没有任何其他消息。

我的状态机定义似乎是有效的,只是没有实际的ARN:

{
  "Comment": "My Workflow",
  "StartAt": "Step1",
  "States": {
    "Step1": {
      "Type": "Task",
      "Resource": "copy-pasted-arn-of-lambda",
      "Next": "Step2"
    },
    "Step2": {
      "Type": "Task",
      "Resource": "arn:aws:states:::ecs:runTask.sync",
      "Parameters": {
        "LaunchType": "FARGATE",
        "Cluster": "copy-pasted-arn-of-cluster",
        "TaskDefinition": "copy-paster-arn-of-task-definition",
        "Overrides": {
          "ContainerOverrides": [
            {
              "Name": "container-name",
              "Command.$": "$.commands"
            }
          ]
        }
      },
      "Next": "Step3",
      "Catch": [
        {
          "ErrorEquals": [
            "States.ALL"
          ],
          "Next": "Step4"
        }
      ]
    },
    "Step3": {
      "Type": "Task",
      "Resource": "copy-pasted-arn-of-lambda",
      "Next": "Step4"
    },
    "Step4": {
      "Type": "Task",
      "Resource": "copy-pasted-arn-of-lambda",
      "End": true
    }
  }
}

这是错误的屏幕截图: enter image description here

有什么想法吗?我已经在这个头上撞了一段时间了。

1 个答案:

答案 0 :(得分:1)

与AWS一样,它都是权限。

我忘记允许我的StepFunction访问事件,这是必需的:

"Action": [
  "events:PutTargets",
  "events:PutRule",
  "events:DescribeRule"
],

https://docs.aws.amazon.com/step-functions/latest/dg/ecs-iam.html

但是,我非常感谢您提供更详细的错误消息!