34

我一直在尝试在无服务器中部署一个 Lambda,以按每小时调用它的 Cron 计划运行。当它被调用时,我希望 Lambda 中的事件由我自己的 JSON 输入而不是来自 Cron 事件的信息填充,这是部署时的默认输入。

在 AWS 控制台中,我可以手动进入 Lambda 的 Cron 触发器,并将输入从“匹配事件”更改为“常量(JSON 文本)”,以获得我想要的结果。由于 Serverless 在部署 Lambda 时会创建此规则,我觉得应该有某种方法可以通过 serverless.yml 文件中的配置更改输入。在搜索无服务器的文档时,我找不到任何东西,所以现在我想知道在当前状态下通过无服务器是否可以做到这一点,如果可以,该怎么做。

任何意见,将不胜感激。

编辑:有一个更新应该添加了这个功能,但是我仍然无法使用无服务器 1.3.0 使用 JSON 的计划进行部署(并且还使用 1.2.0 进行了测试)。我使用的 serverless.yml 的一些示例如下:

functions:
  test:
    handler: test.test
    description: "test serverless Lambda"
    memorySize: 128
    timeout: 300
    events:
      - schedule:
        rate: rate(10 minutes)
        input:
          key: value
      - schedule:
        rate: rate(10 minutes)
        input: '{"key": "value"}'
      - schedule:
        rate: rate(10 minutes)
        input:
          key: 'value'

从 1.3.0 开始,是否有人能够评论 Serverless 中此功能的状态,以及我上面的 serverless.yml 是否看起来不错?

编辑 2:发布工作 serverless.yml

functions:
  test:
    handler: test.test
    description: "test serverless Lambda"
    memorySize: 128
    timeout: 300
    events:
      - schedule:
          rate: rate(10 minutes)
          enabled: true
          input:
            key: value
      - schedule:
          rate: rate(10 minutes)
          input: '{"key": "value"}'
          enabled: true
      - schedule:
          rate: rate(10 minutes)
          input:
            key: 'value'
          enabled: true
4

1 回答 1

28

编辑您的编辑:我做了一些挖掘,如果它不是字符串,似乎无服务器会自动禁用计划。这意味着如果您的整个活动是- schedule: rate(10 minutes),它将被启用。但是,如果您有其他属性,则必须启用它,因为默认情况下它将被禁用。

所以你当前的 .yml 应该是这样的:

functions:   test:
    handler: test.test
    description: "test serverless Lambda"
    memorySize: 128
    timeout: 300
    events:
      - schedule:
        rate: rate(10 minutes)
        enabled: true
        input:
          key: value
      - schedule:
        rate: rate(10 minutes)
        input: '{"key": "value"}'
        enabled: true
      - schedule:
        rate: rate(10 minutes)
        input:
          key: 'value'
        enabled: true

您可以在 serverless.yml 文件中使用相同的内容inputinputPath就像使用 cloudwatch 事件规则一样。与 cloudwath 规则的唯一区别在于,您实际上可以传递一个对象,而无服务器会自动为您将其字符串化。

例子:

functions:
  crawl:
    handler: crawl
    events:
      - schedule: 
          rate: rate(1 hours)
          input: 
            key1: value1
            key2: value2

这将等于 cloudformation 事件规则,input:"{'key1':'value1','key2':'value2'}"因此传递 json 而不是匹配的事件。

刚才注意到这个问题是在 11 月 2 日提出的。当时不可能这样做,但在提出问题后不久就实施了。https://github.com/serverless/serverless/pull/2567

于 2016-12-11T09:04:09.793 回答