使用 cloudformation yaml 在 Lambda 函数上添加 S3 触发器
add S3 trigger on a Lambda function with cloudformation yaml
所以我想解决这个问题:
- 创建 S3 存储桶
- 将此 S3 存储桶作为触发器添加到我正在使用的当前 lambda 函数。
这是必须在 YAML 中完成的事情
我不知道如何设置...
到目前为止,我所做的是创建一个完美运行的 s3 存储桶,现在我只需要将它作为触发器附加到 lambda 函数。
在 AWS 控制台中进行设置非常容易,但我对 YAML 的使用经验不多。所以我不知道如何正确设置它,而且该文件非常敏感,所以它很痛苦:-)。
- 运行时间:node.js10.x
希望使用 yaml 的最终结果:
我建了一个小模板,测试过。
模板是
- 创建 S3 存储桶。它是触发器 Lambda,所有文件都以 txt 结尾。
如果您不想要任何过滤器,请从模板中删除过滤器
- Create Permission,让S3可以触发Lambda函数。 (注意:我只是
假名,请相应更改)
- 创建 Lambda(注意:我使用的是现有角色 arn:aws:iam::057351434671:role/lambda_sqs 但您可以创建或使用您组织中的其他角色)
YML版本
---
AWSTemplateFormatVersion: '2010-09-09'
Description: This template is to create all resources for Config Service Api
Parameters:
LambdaArtifactBucketName:
Type: String
Default: befit-artifact
S3BucketName:
Type: String
Default: befit-test-s3
Resources:
ExampleS3:
Type: AWS::S3::Bucket
DependsOn: ExampleInvokePermission
Properties:
BucketName: !Ref S3BucketName
NotificationConfiguration:
LambdaConfigurations:
- Event: s3:ObjectCreated:Put
Filter:
S3Key:
Rules:
- Name: suffix
Value: txt
Function: !GetAtt [ ExampleLambdaFunction, Arn]
ExampleInvokePermission:
Type: AWS::Lambda::Permission
DependsOn: ExampleLambdaFunction
Properties:
FunctionName:
Fn::GetAtt:
- ExampleLambdaFunction
- Arn
Action: lambda:InvokeFunction
Principal: s3.amazonaws.com
SourceArn:
Fn::Sub: arn:aws:s3:::${S3BucketName}
ExampleLambdaFunction:
Type: AWS::Lambda::Function
Properties:
Code:
S3Bucket:
Ref: LambdaArtifactBucketName
S3Key: emailnotification-1.0.0.jar
FunctionName: example-lambda-function
Handler: com.xxx.Example::handleRequest
Role: arn:aws:iam::057351434671:role/lambda_sqs
Runtime: java8
Timeout: '300'
MemorySize: 512
Outputs:
S3BucketSecureURL:
Value: !Join ['', ['https://', !GetAtt [ExampleS3, DomainName]]]
Description: Name of S3 bucket
Json版本
{
"AWSTemplateFormatVersion": "2010-09-09",
"Description": "This template is to create all resources for Config Service Api",
"Parameters": {
"LambdaArtifactBucketName": {
"Type": "String",
"Default": "befit-artifact"
},
"S3BucketName": {
"Type": "String",
"Default": "befit-test-s3"
}
},
"Resources": {
"ExampleS3": {
"Type": "AWS::S3::Bucket",
"DependsOn": "ExampleInvokePermission",
"Properties": {
"BucketName": null,
"NotificationConfiguration": {
"LambdaConfigurations": [
{
"Event": "s3:ObjectCreated:Put",
"Filter": {
"S3Key": {
"Rules": [
{
"Name": "suffix",
"Value": "txt"
}
]
}
},
"Function": null
}
]
}
}
},
"ExampleInvokePermission": {
"Type": "AWS::Lambda::Permission",
"DependsOn": "ExampleLambdaFunction",
"Properties": {
"FunctionName": {
"Fn::GetAtt": [
"ExampleLambdaFunction",
"Arn"
]
},
"Action": "lambda:InvokeFunction",
"Principal": "s3.amazonaws.com",
"SourceArn": {
"Fn::Sub": "arn:aws:s3:::${S3BucketName}"
}
}
},
"ExampleLambdaFunction": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"S3Bucket": {
"Ref": "LambdaArtifactBucketName"
},
"S3Key": "emailnotification-1.0.0.jar"
},
"FunctionName": "example-lambda-function",
"Handler": "com.xxx.Example::handleRequest",
"Role": "arn:aws:iam::057351434671:role/lambda_sqs",
"Runtime": "java8",
"Timeout": "300",
"MemorySize": 512
}
}
},
"Outputs": {
"S3BucketSecureURL": {
"Value": null,
"Description": "Name of S3 bucket"
}
}
}
在模板运行之后,输出将是
谢谢,
所以我想解决这个问题:
- 创建 S3 存储桶
- 将此 S3 存储桶作为触发器添加到我正在使用的当前 lambda 函数。
这是必须在 YAML 中完成的事情
我不知道如何设置... 到目前为止,我所做的是创建一个完美运行的 s3 存储桶,现在我只需要将它作为触发器附加到 lambda 函数。
在 AWS 控制台中进行设置非常容易,但我对 YAML 的使用经验不多。所以我不知道如何正确设置它,而且该文件非常敏感,所以它很痛苦:-)。
- 运行时间:node.js10.x
希望使用 yaml 的最终结果:
我建了一个小模板,测试过。
模板是
- 创建 S3 存储桶。它是触发器 Lambda,所有文件都以 txt 结尾。 如果您不想要任何过滤器,请从模板中删除过滤器
- Create Permission,让S3可以触发Lambda函数。 (注意:我只是 假名,请相应更改)
- 创建 Lambda(注意:我使用的是现有角色 arn:aws:iam::057351434671:role/lambda_sqs 但您可以创建或使用您组织中的其他角色)
YML版本
---
AWSTemplateFormatVersion: '2010-09-09'
Description: This template is to create all resources for Config Service Api
Parameters:
LambdaArtifactBucketName:
Type: String
Default: befit-artifact
S3BucketName:
Type: String
Default: befit-test-s3
Resources:
ExampleS3:
Type: AWS::S3::Bucket
DependsOn: ExampleInvokePermission
Properties:
BucketName: !Ref S3BucketName
NotificationConfiguration:
LambdaConfigurations:
- Event: s3:ObjectCreated:Put
Filter:
S3Key:
Rules:
- Name: suffix
Value: txt
Function: !GetAtt [ ExampleLambdaFunction, Arn]
ExampleInvokePermission:
Type: AWS::Lambda::Permission
DependsOn: ExampleLambdaFunction
Properties:
FunctionName:
Fn::GetAtt:
- ExampleLambdaFunction
- Arn
Action: lambda:InvokeFunction
Principal: s3.amazonaws.com
SourceArn:
Fn::Sub: arn:aws:s3:::${S3BucketName}
ExampleLambdaFunction:
Type: AWS::Lambda::Function
Properties:
Code:
S3Bucket:
Ref: LambdaArtifactBucketName
S3Key: emailnotification-1.0.0.jar
FunctionName: example-lambda-function
Handler: com.xxx.Example::handleRequest
Role: arn:aws:iam::057351434671:role/lambda_sqs
Runtime: java8
Timeout: '300'
MemorySize: 512
Outputs:
S3BucketSecureURL:
Value: !Join ['', ['https://', !GetAtt [ExampleS3, DomainName]]]
Description: Name of S3 bucket
Json版本
{
"AWSTemplateFormatVersion": "2010-09-09",
"Description": "This template is to create all resources for Config Service Api",
"Parameters": {
"LambdaArtifactBucketName": {
"Type": "String",
"Default": "befit-artifact"
},
"S3BucketName": {
"Type": "String",
"Default": "befit-test-s3"
}
},
"Resources": {
"ExampleS3": {
"Type": "AWS::S3::Bucket",
"DependsOn": "ExampleInvokePermission",
"Properties": {
"BucketName": null,
"NotificationConfiguration": {
"LambdaConfigurations": [
{
"Event": "s3:ObjectCreated:Put",
"Filter": {
"S3Key": {
"Rules": [
{
"Name": "suffix",
"Value": "txt"
}
]
}
},
"Function": null
}
]
}
}
},
"ExampleInvokePermission": {
"Type": "AWS::Lambda::Permission",
"DependsOn": "ExampleLambdaFunction",
"Properties": {
"FunctionName": {
"Fn::GetAtt": [
"ExampleLambdaFunction",
"Arn"
]
},
"Action": "lambda:InvokeFunction",
"Principal": "s3.amazonaws.com",
"SourceArn": {
"Fn::Sub": "arn:aws:s3:::${S3BucketName}"
}
}
},
"ExampleLambdaFunction": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"S3Bucket": {
"Ref": "LambdaArtifactBucketName"
},
"S3Key": "emailnotification-1.0.0.jar"
},
"FunctionName": "example-lambda-function",
"Handler": "com.xxx.Example::handleRequest",
"Role": "arn:aws:iam::057351434671:role/lambda_sqs",
"Runtime": "java8",
"Timeout": "300",
"MemorySize": 512
}
}
},
"Outputs": {
"S3BucketSecureURL": {
"Value": null,
"Description": "Name of S3 bucket"
}
}
}
在模板运行之后,输出将是
谢谢,