0

我有一个使用 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)

提前致谢

4

1 回答 1

1

这在今天是不可能的。我们正在考虑将来使用此功能(CFN 属性传递)。

于 2019-03-07T14:15:37.627 回答