繁体   English   中英

如何使用 AWS Step Functions 将失败任务的输入和错误传递给回退任务?

[英]How can I pass the input and error of my failing task to a fallback task using AWS Step Functions?

我正在尝试向我的步骤函数状态机添加一些错误处理,并且我在特定场景中遇到了问题,例如,如果我在某个步骤上失败了,我可以将其发送到另一个函数,但是在该功能我需要使用最后一步输入数据(失败的那个)来执行逻辑,但是,我只是收到一个错误,有没有办法传递带有错误的输入数据?

Send Notification:
        Type: Task
        Resource: !GetAtt CommunicationSendCertifiedEmail.Arn
        Retry:
          - ErrorEquals:
            - TierOneError
            IntervalSeconds: 2
            MaxAttempts: 9
            BackoffRate: 1.5
          - ErrorEquals:
            - TierTwoError
            IntervalSeconds: 4
            MaxAttempts: 6
            BackoffRate: 1.5
          - ErrorEquals:
            - TierThreeError
            IntervalSeconds: 4
            MaxAttempts: 3
            BackoffRate: 2
          - ErrorEquals:
            - States.Timeout
            - States.Runtime
            - States.TaskFailed
            - Lambda.ServiceException
            IntervalSeconds: 4
            MaxAttempts: 3
            BackoffRate: 2
        Catch:
          - ErrorEquals:
            - States.ALL
            Next: Send Email Notification

在“发送电子邮件通知”上是我在执行失败之前需要输入的地方,但正如我之前所说,我只是得到这样的东西:

{
  "Error": "Error",
  "Cause": "{\"errorType\":\"Error\",\"errorMessage\":...
}

我想得到这样的东西:

{
  "data": "{...}",
  "Error": "Error",
  "Cause": "{\"errorType\":\"Error\",\"errorMessage\":...
}

有任何想法吗? 甚至有可能吗?

Catch使用ResultPath将错误包含在原始输入中,而不是替换它。

结果路径(可选)

确定将哪些输入发送到 Next 字段中指定的状态的路径。


如果未指定ResultPath字段,则默认为$

这将选择并覆盖整个输入以将其替换为状态输出(在这种情况下是错误的),这就是为什么您没有获得任何输入数据的原因。

这是一个示例 -这不是您想要的,而是当前正在发生的事情

在此处输入图片说明


为错误输出应该去的位置指定一个ResultPath

这样一来,它会采取的状态输出(这是一个错误在这种情况下),并包括它与输入。

这不会覆盖所有状态输入,这允许您保留输入。

这是一个例子 -这就是你想要的

在此处输入图片说明


尝试:

Catch:
  - ErrorEquals:
    - States.ALL
    Next: Send Email Notification
    ResultPath: $.error

如果前面的Catch声明捕获了一个错误,它会包括一个错误输出error状态下输入节点(节点被称为error ,因为我们指定的路径是$.error )。

这就像上面的第二个图。


例如,如果发送通知的状态输入是:

{
    "foo": "bar"
}

当捕获错误时,发送到Send Email Notification的状态输出将如下所示。

{
  "foo": "bar",
  "error": {
    "Error": "Error here"
  }
}

它也可能是下面的,因为对象通常还包含Cause字段(就像你的情况一样)。 该字段的值是人类可读的错误描述。

{
  "foo": "bar",
  "error": {
    "Error": "Error here",
    "Cause": "{\"errorType\":\"Error\",\"errorMessage\"
  }
}

重要的提示:

根据您的输入数据为error节点选择一个唯一的名称,因为我刚刚将error用于演示目的。

如果指定的节点已经存在,例如您已经有一个名称为error的字段,则ResultPath将使用您不想要的错误输出更新并覆盖该节点。

一张图片值一千字,所以这是使用ResultPath可能的第三条路径(同样,这不是你想要的):

在此处输入图片说明


如果您好奇,最后一条可能的路径(与问题无关但很高兴知道)是丢弃状态结果(您需要它,因此它不相关)并保留原始输入。

设置ResultPathnull实现这一点,因为概述这里

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM