3 amazon-web-services amazon-sns aws-cloudformation aws-lambda
使用云形成从 SNS 触发 lambda?
您不应忘记添加LambdaFunctionPermission以允许使用 SNS 主题。
这是 yaml 中 Cloud Formation 模板的资源部分:
Resources:
SNSTopic:
Type: AWS::SNS::Topic
Properties:
DisplayName: sns-topic-for-lambda
TopicName: sns-topic-for-lambda
Subscription:
- Endpoint: !GetAtt LambdaFunction.Arn
Protocol: lambda
LambdaFunctionPermission:
Type: AWS::Lambda::Permission
Properties:
Action: lambda:InvokeFunction
FunctionName: !GetAtt LambdaFunction.Arn
Principal: sns.amazonaws.com
LambdaFunction:
Type: AWS::Lambda::Function
Properties:
...
Run Code Online (Sandbox Code Playgroud)
我们所做的是我们不将 sns 指向一个不合格的 lambda,而是将它指向一个 lambda 别名。基本上,创建一个 lambda,然后创建一个别名,使用 sns 指向该 lambda 别名。
当您有新的 lambda 代码(您的 ci/cd 可以执行以下操作)时,更新 lambda 函数代码,创建新的 lambda 版本,并将您的别名重新指向新版本。这样,您的 sns 就不必因新的 lambda 代码删除而发生任何变化。
Resources:
AwsServerlessExpressFunction:
Type: AWS::Serverless::Function
Properties:
FunctionName: mylambda
Description: mylambda
Runtime: nodejs8.10
Handler: index.handler
MemorySize: 512
Timeout: 60
Role: !Ref LambdaExecutionRoleArn
AwsServerlessExpressFunctionAlias:
Type: AWS::Lambda::Alias
Properties:
FunctionName: !Ref AwsServerlessExpressFunction
FunctionVersion: '$LATEST'
Name: live
SNSTopic:
Type: AWS::SNS::Topic
Properties:
DisplayName: mysnstopic
TopicName: mysnstopic
Subscription:
-
Endpoint: !Ref AwsServerlessExpressFunctionAlias
Protocol: lambda
LambdaInvokePermission:
Type: AWS::Lambda::Permission
Properties:
Action: lambda:InvokeFunction
Principal: sns.amazonaws.com
SourceArn: !Ref SNSTopic
FunctionName: !Ref AwsServerlessExpressFunctionAlias
Run Code Online (Sandbox Code Playgroud)
您可以使用事件来设置触发器。
lambda:
Type: 'AWS::Serverless::Function'
Properties:
Handler:
------
Events:
SNS1:
Type: SNS
Properties:
Topic:
Ref: SNSTopic1
SNSTopic1:
Type: 'AWS::SNS::Topic'
Run Code Online (Sandbox Code Playgroud)
参考:参考: https: //docs.aws.amazon.com/lambda/latest/dg/serverless_app.html#serverless_app_resources
| 归档时间: |
|
| 查看次数: |
8882 次 |
| 最近记录: |