我希望每当文件上传到s3存储桶时都会收到电子邮件,如上面的标题所述,我使用无服务器,问题是我在s3上创建的事件只给了我关于s3-aws控制台的通知,并且不知道如何在S3上配置cloudwatch事件以触发lambda。所以,如果有人知道如何使用cloudwatch触发S3上的事件我很满意。 这是我的代码:
import json
import boto3
import botocore
import logging
import sys
import os
import traceback
from botocore.exceptions import ClientError
from pprint import pprint
from time import strftime, gmtime
email_from = '*****@******.com'
email_to = '******@******.com'
#email_cc = '********@gmail.com'
email_subject = 'new event on s3 '
email_body = 'a new file is uploaded'
#setup simple logging for INFO
logger = logging.getLogger()
logger.setLevel(logging.INFO)
from botocore.exceptions import ClientError
def sthree(event, context):
"""Send email whenever a file is uploaded to S3"""
body = {}
status_code = 200
try:
s3 = boto3.client('s3')
ses = boto3.client('ses')
response = ses.send_email(Source = email_from,
Destination = {'ToAddresses': [email_to,],},
Message = {'Subject': {'Data': email_subject}, 'Body':{'Text' : {'Data': email_body}}}
)
response = {
"statusCode": 200,
"body": json.dumps(body)
}
return response
这是我的serverless.yml文件
service: aws-python # NOTE: update this with your service name
plugins:
- serverless-external-s3-event
provider: name: aws
runtime: python2.7
stage: dev
region: us-east-1
iamRoleStatements:
- Effect: "Allow"
Action:
- s3:*
- "ses:SendEmail"
- "ses:SendRawEmail"
- "s3:PutBucketNotification"
Resource: "*"
functions: sthree:
handler: handler.sthree
description: send mail whenever a file is uploaded on S3
events:
- s3:
bucket: cartegie-nirmine
event: s3:ObjectCreated:*
rules:
- prefix: uploads/
- suffix: .jpg
- cloudwatchEvent:
description: 'CloudWatch Event triggered '
event:
source:
- "aws.S3"
detail-type:
- "S3 event Notification"
enabled : true
答案 0 :(得分:2)
如果你的座右铭只是接收S3存储桶操作的电子邮件通知,那么你就不需要lambda函数了。对于问题中提到的用例,您可以使用SNS主题和S3事件来实现。我将提到从控制台跟随的步骤(通过sdk或cli可以实现相同的步骤)。
1)使用SNS控制台创建Topic
。
2)订阅主题。使用email
作为通讯协议,并提供 电子邮件ID 。
3)您将收到电子邮件,要求您确认对该主题的订阅。确认订阅。
4)重要:使用以下政策替换主题的访问政策:
{
"Version": "2008-10-17",
"Id": "__default_policy_ID",
"Statement": [
{
"Sid": "__default_statement_ID",
"Effect": "Allow",
"Principal": {
"AWS": "*"
},
"Action": "SNS:Publish",
"Resource": "sns-topic-arn",
"Condition": {
"ArnLike": {
"aws:SourceArn": "arn:aws:s3:*:*:s3-bucket-name"
}
}
}
]
}
基本上,您授权 s3-bucket 发布到SNS主题。
将 sns-topic-arn 替换为您在上面创建的主题的ARN。 使用您要为其接收通知的存储桶名称重新显示 s3-bucket-name 。
5)转到S3控制台。单击您的S3存储桶并打开属性选项卡。
6)在 高级设置 下,点击 活动 卡。
7)点击添加通知并输入值。示例如下所示。
选择要监控的所需s3事件和您创建的SNS主题。
8)点击保存。现在您应该开始收到您的电子邮件通知。