无法将AWS S3与AWS Lambda链接

时间:2015-09-17 17:31:46

标签: amazon-web-services amazon-s3 aws-lambda

我想将AWS S3与我的AWS Lambda联系起来。我创建了我的s3存储桶并将其命名为xyz。在我的AWS Lambda函数上创建事件源时,它显示以下错误

There was an error creating the event source mapping: Your bucket must be in the same region as the function.

在浏览此link时,我发现我需要为AWS Lambda函数设置s3存储桶的事件通知。但是我无法为s3存储桶设置事件通知,因为它没有在s3存储桶属性的事件选项卡中显示AWS lambda函数的设置。

我为Lambda创建的IAM角色的策略文档如下

{
"Version": "VersionNumber",
"Statement": [
    {
        "Effect": "Allow",
        "Action": [
            "logs:CreateLogGroup",
            "logs:CreateLogStream",
            "logs:PutLogEvents"
        ],
        "Resource": "arn:aws:logs:*:*:*"
    },
    {
        "Effect": "Allow",
        "Action": [
            "s3:GetObject",
            "s3:PutObject"
        ],
        "Resource": [
            "arn:aws:s3:::xyz/*"
        ]
    }
   ]
 }

有人可以告诉我为什么我无法为s3存储桶上的操作创建AWS Lambda事件吗?

1 个答案:

答案 0 :(得分:6)

感谢John的评论,我能够解决这个问题。

当(错误消息明确说明)Lambda和S3存储桶位于不同区域时,会出现此问题。

要在与s3 bucket相同的区域中创建lambda,您需要知道bucket的区域。

  

要查看Amazon S3存储桶的区域,请单击管理控制台中的存储桶,然后转到“属性”选项卡。将显示该区域

现在您已了解目标区域。您可以在aws控制台中切换到该区域,方法是在Support菜单之前的右上角的下拉选择菜单中选择一个区域。

将区域更改为s3存储区域后,创建新的lambda函数将解决此问题。