[英]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
。
这样一来,它会采取的状态输出(这是一个错误在这种情况下),并包括它与输入。
这不会覆盖所有状态输入,这允许您保留输入。
这是一个例子 -这就是你想要的:
尝试:
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
可能的第三条路径(同样,这不是你想要的):
如果您好奇,最后一条可能的路径(与问题无关但很高兴知道)是丢弃状态结果(您需要它,因此它不相关)并保留原始输入。
设置ResultPath
到null
实现这一点,因为概述这里。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.