gpt4 book ai didi

aws-lambda - AWS 步骤函数中的重试逻辑

转载 作者:行者123 更新时间:2023-12-02 17:27:50 28 4
gpt4 key购买 nike

我正在测试step函数的重试逻辑。理论上,如果失败,应该重试以下步骤函数来执行 lambda 3 次。

{
"StartAt": "Bazinga",
"States": {
"Bazinga": {
"Type": "Task",
"Resource": "arn:aws:states:::lambda:invoke",
"Parameters": {
"FunctionName": "arn:aws:lambda:ap-southeast-2:518815385770:function:errorTest:$LATEST",
"Payload": {
"Input.$": "$"
}
},
"Retry" : [
{
"ErrorEquals": [ "States.All", "States.Timeout" ],
"IntervalSeconds": 1,
"MaxAttempts": 3,
"BackoffRate": 1.0
}
],
"Next": "Fail"
},
"Fail": {
"Type": "Fail"
}
}
}

它调用的 lambda 设置为 3 秒后超时。 lambda 卡住 4 秒。这意味着 lambda 超时并抛出 States.Timeout 错误。代码如下:

function sleep(ms){
return new Promise(resolve=>{
setTimeout(resolve,ms)
})
}

exports.handler = async (event) => {
console.log('------------> executing ....')
await sleep(4000)
};

问题是步骤函数不会重试该任务。这可以从以下 CloudWatch 日志中得到确认。


05:59:36
START RequestId: dd1a2ee9-f389-44be-aaa6-07f2ca7983b0 Version: $LATEST

05:59:36
2019-07-24T05:59:36.340Z dd1a2ee9-f389-44be-aaa6-07f2ca7983b0 INFO ------------> executing ....

05:59:39
END RequestId: dd1a2ee9-f389-44be-aaa6-07f2ca7983b0

05:59:39
REPORT RequestId: dd1a2ee9-f389-44be-aaa6-07f2ca7983b0 Duration: 3003.29 ms Billed Duration: 3000 ms Memory Size: 128 MB Max Memory Used: 26 MB

05:59:39
2019-07-24T05:59:39.317Z dd1a2ee9-f389-44be-aaa6-07f2ca7983b0 Task timed out after 3.00 seconds

不知道出了什么问题。感谢任何帮助,提前致谢。

最佳答案

为了回答我自己的问题,我放置的重试逻辑有两个问题。

  1. States.All 应该是 States.ALL(注意 L 的大小写)
  2. 当 lambda 超时时,抛出的错误是 Lambda.Unknown 而不是 States.Timeout

我使用以下代码更新了我的步骤函数,现在它可以工作了:

{
"StartAt": "Bazinga",
"States": {
"Bazinga": {
"Type": "Task",
"Resource": "arn:aws:states:::lambda:invoke",
"Parameters": {
"FunctionName": "arn:aws:lambda:ap-southeast-2:518815385770:function:errorTest:$LATEST",
"Payload": {
"Input.$": "$"
}
},
"Retry" : [
{
"ErrorEquals": [ "States.Timeout", "Lambda.Unknown" ],
"IntervalSeconds": 1,
"MaxAttempts": 3,
"BackoffRate": 1.0
}
],
"Next": "Fail"
},
"Fail": {
"Type": "Fail"
}
}
}

关于aws-lambda - AWS 步骤函数中的重试逻辑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57174134/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com