我有一个使用 SAM 模板创建的 lambda 函数,该函数每 5 分钟安排一次事件触发器。
当第一次创建 lambda 时,事件被启用。但是,当有人手动禁用触发器时,重新运行堆栈不会再次启用它。
原生云形成有一个名为AWS::Events::RuleState
的属性。但这在 SAM 函数的 Events 属性中不受支持。请注意,此 Events 属性由 SAM 引擎转换为 AWS::Events::Rule。
我尝试在 SAM 中添加相同的 State 属性,但这不起作用。
现在的问题实际上是如何确保在使用 SAM 时始终启用事件。
这有一个黑客可用。
示例代码:
MyUpdater:
Type: 'AWS::Serverless::Function'
Properties:
Handler: myupdater.lambda_handler
Runtime: python3.6
FunctionName: "myupdater"
CodeUri: ./code
Description: Sample updater lambda
MemorySize: 128
Timeout: 60
Role: !ImportValue myIamRole
KmsKeyArn: !ImportValue myKeyArn
Events:
Timer:
Type: Schedule
Properties:
Schedule: rate(5 minutes)
提前致谢