错误处理程序未捕获 Aws 步骤函数超时
Aws step function timeout not catched by error handler
我有以下状态,其中超时未被捕获,但是有“States.ALL”的捕获。根据这里 https://docs.aws.amazon.com/step-functions/latest/dg/concepts-error-handling.html
它应该是。你能告诉我哪里出了问题吗?
"PublishIotCmd&WaitTask": {
"Next": "SuccedTask",
"Retry": [
{
[..]
}
],
"Catch": [
{
"ErrorEquals": [
"States.ALL"
],
"ResultPath": "$.error",
"Next": "ErrorHandlerTask"
}
],
"Type": "Task",
"TimeoutSeconds": 600,
"ResultPath": "$.cmdResult",
"Resource": "arn:aws:states:::lambda:invoke.waitForTaskToken",
"Parameters": {
"FunctionName": "xx",
"Payload": {
"token.$": "$$.Task.Token",
"request.$": "$.detail"
}
}
},
在特定情况下,超时是由于任务没有通过 sendTaskSuccess 获得令牌。错误当然是这个,但是没有调用“ErrorHandlerTask”,状态机就挂了。
const publishIot = new tasks.LambdaInvoke(this, 'PublishIotCmd&WaitTask', {
lambdaFunction: iotSendCommandFn,
payload: sfn.TaskInput.fromObject({
token: sfn.JsonPath.taskToken,
//request: sfn.JsonPath.entirePayload,
request: sfn.JsonPath.stringAt('$.detail'),
}),
resultPath: '$.cmdResult',
integrationPattern: sfn.IntegrationPattern.WAIT_FOR_TASK_TOKEN,
timeout: Duration.minutes(TIMEOUT_WAIT_REPLY_SECONDS),
提前致谢
对于任务令牌,我相信您应该使用 Heartbeat 超时而不是一般超时。
在文档中它指出““HeartbeatSeconds”:600 字段将心跳超时间隔设置为 10 分钟。”并且“如果等待任务在 10 分钟内没有收到有效的任务令牌,任务将失败并显示 States.Timeout 错误名称。”
我想因为它是一个不同的服务集成 Heartbeat 在这里工作。
https://docs.aws.amazon.com/step-functions/latest/dg/connect-to-resource.html#connect-wait-token
我有以下状态,其中超时未被捕获,但是有“States.ALL”的捕获。根据这里 https://docs.aws.amazon.com/step-functions/latest/dg/concepts-error-handling.html 它应该是。你能告诉我哪里出了问题吗?
"PublishIotCmd&WaitTask": {
"Next": "SuccedTask",
"Retry": [
{
[..]
}
],
"Catch": [
{
"ErrorEquals": [
"States.ALL"
],
"ResultPath": "$.error",
"Next": "ErrorHandlerTask"
}
],
"Type": "Task",
"TimeoutSeconds": 600,
"ResultPath": "$.cmdResult",
"Resource": "arn:aws:states:::lambda:invoke.waitForTaskToken",
"Parameters": {
"FunctionName": "xx",
"Payload": {
"token.$": "$$.Task.Token",
"request.$": "$.detail"
}
}
},
在特定情况下,超时是由于任务没有通过 sendTaskSuccess 获得令牌。错误当然是这个,但是没有调用“ErrorHandlerTask”,状态机就挂了。
const publishIot = new tasks.LambdaInvoke(this, 'PublishIotCmd&WaitTask', {
lambdaFunction: iotSendCommandFn,
payload: sfn.TaskInput.fromObject({
token: sfn.JsonPath.taskToken,
//request: sfn.JsonPath.entirePayload,
request: sfn.JsonPath.stringAt('$.detail'),
}),
resultPath: '$.cmdResult',
integrationPattern: sfn.IntegrationPattern.WAIT_FOR_TASK_TOKEN,
timeout: Duration.minutes(TIMEOUT_WAIT_REPLY_SECONDS),
提前致谢
对于任务令牌,我相信您应该使用 Heartbeat 超时而不是一般超时。
在文档中它指出““HeartbeatSeconds”:600 字段将心跳超时间隔设置为 10 分钟。”并且“如果等待任务在 10 分钟内没有收到有效的任务令牌,任务将失败并显示 States.Timeout 错误名称。”
我想因为它是一个不同的服务集成 Heartbeat 在这里工作。
https://docs.aws.amazon.com/step-functions/latest/dg/connect-to-resource.html#connect-wait-token