【发布时间】:2018-03-29 14:21:09
【问题描述】:
我正在尝试在包含它的 s3 存储桶更新时部署我的 lambda 函数。
如果我知道我有最新的 zip lambda 代码,我可以简单地使用云形成来自动创建和部署 lambda 函数
{
"AWSTemplateFormatVersion": "2010-09-09",
"Description": "AWS CloudFormation CloudWatch Log Janitor Demo Stack",
"Resources": {
"TestLamdaRole": {
"Type": "AWS::IAM::Role",
"Properties": {
"AssumeRolePolicyDocument": {
"Version": "2012-10-17",
"Statement": [{
"Effect": "Allow",
"Principal": {
"Service": [
"lambda.amazonaws.com"
]
},
"Action": [
"sts:AssumeRole"
]
}]
},
"Path": "/"
}
},
"EbsBackupExecutionPolicy": {
"DependsOn": [
"TestLamdaRole"
],
"Type": "AWS::IAM::Policy",
"Properties": {
"PolicyName": "hamedlamdapolicytest",
"Roles": [{
"Ref": "TestLamdaRole"
}],
"PolicyDocument": {
"Version": "2012-10-17",
"Statement": [{
"Effect": "Allow",
"Action": [
"logs:*"
],
"Resource": [
"arn:aws:lambda:us-east-1:1111111111111:function:*"
]
},
{
"Effect": "Allow",
"Action": [
"ec2:Describe*"
],
"Resource": [
"*"
]
}
]
}
}
},
"LambdaFuction": {
"Type": "AWS::Lambda::Function",
"Properties": {
"Code": {
"S3Bucket": "lambda-dep-test",
"S3Key": "index.zip"
},
"Role": {
"Fn::GetAtt": [
"TestLamdaRole",
"Arn"
]
},
"Timeout": 60,
"Handler": "lambda_function.handler",
"Runtime": "nodejs6.10",
"MemorySize": 128,
"FunctionName": "stg1-test"
}
}
}
}
但问题是,一旦我运行上面的 lambda 代码,那么每当用户将某物放入存储桶时,最新的代码都不会自动部署。我知道它与 lambda 有关,但我迷路了,我不知道使用哪种方法以及从哪里开始。你能解释一下吗?
【问题讨论】:
-
没有直接的方法可以实现这一点。在 S3 中创建一个事件。每当添加新文件时,该事件将触发一个不同的 Lambda 函数,该函数将更新原始函数(在本例中:stg1-test)
标签: amazon-web-services amazon-s3 aws-lambda amazon-cloudformation aws-opsworks