使用 AWS SDK 为事件桥规则添加 AWS Lambda 作为目标

adding AWS Lambda as target using AWS SDK for event bridge rule

我正在使用无服务器框架和 AWS Node.js SDK 将基于计划的 cron 表达式的规则添加到默认事件总线。

 eventBridge.putRule(params, function (err, data) {...

之后我将目标添加到此规则。

const params = {
    Rule: data.ruleName,
    Targets: [ 
        {
            Arn: process.env.SCHEDULED_EVENT_LAMBDA_ARN, /* required */
            Id: process.env.SCHEDULED_EVENT_LAMBDA_ID, /* required */
            Input: JSON.stringify(someData)
        },
        
    ],
    
};

eventBridge.putTargets(params, function (err, data) {...

在事件桥上动态创建的计划 cron 规则上添加目标成功,但是当我导航到 lambda 仪表板时,触发层似乎没有更新,最终没有触发 lambda 函数。

事件桥 putTargets 的 AWS SDK 文档提到:

For AWS Lambda and Amazon SNS resources, EventBridge relies on resource-based policies

因此,如果资源策略是问题(未确认),是否有任何关于资源策略的配置,我可以在 serverless.yml 文件中为允许事件桥服务添加要部署的层的特定功能设置目标 lambda 函数。

对于动态生成,您可以使用 AddPermission 添加必要的权限。


function addPermission ({ lambdaArn, restApiId }) {
 const { region, namespace } = parseArn(lambdaArn)

 const params = {
  Action: 'lambda:InvokeFunction',
  FunctionName: lambdaArn,
  Principal: 'events.amazonaws.com',
  StatementId: `scheduleName`,
  SourceArn: `RuleARN`
 }

 return lambda.addPermission(params).promise()
}

如果您正在使用 serverless 框架。

functions:
  myFunction:
    handler: index.handler
    events:
      - eventBridge:
          schedule: rate(10 minutes)
          input:
            key1: value1

以上定义只是创建规则并将您的 lambda 添加为目标。它将处理必要的权限以及需要的权限。

设置事件模式匹配

EventBridge Use Cases and Examples

Schedule