Lambda发送SNS通知

时间:2018-10-10 10:40:35

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

我有一个S3存储桶-当对象(csv被加载)时-lambda被触发。然后Lambda将此csv并上传到Dynamo DB中。现在,在Dynam DB更新之后-我需要发送SNS通知。

下面是我的代码。下面的代码插入到Dynamo DB中-但是,它不会脱离循环执行SNS部分。 如果我注释掉-for loop(put_item),则SNS可以正常工作,并且我能够收到通知。

import os
import boto3
import json
import logging

log_level = os.environ['LOG_LEVEL']
log = logging.getLogger(__name__)
logging.getLogger().setLevel(log_level)

def lambda_handler(event, context):

    # Fetch the bucket name and the file
    bucket = event['Records'][0]['s3']['bucket']['name']
    key = event['Records'][0]['s3']['object']['key']

    log.info("Event: " + (str(event)))

    # Generate record in DynamoDB
    try :
        # Declare S3 bucket and DynamoDB Boto3 Clients
        s3_client = boto3.client('s3')
        dynamodb = boto3.resource('dynamodb')

        # Read the Object using get_object API
        obj = s3_client.get_object(Bucket=bucket, Key=key)
        rows = obj['Body'].read().decode("utf-8").split('\n')

        tableName = os.environ['DB_TABLE_NAME']
        table = dynamodb.Table(tableName)

        log.info("TableName: " + tableName)


        try :
            # Write the CSV file to the DynamoDB Table
            with table.batch_writer() as batch:
                for row in rows:       
                    batch.put_item(Item={
                        'A': row.split(',')[0],
                        'B': row.split(',')[1],
                        'C': row.split(',')[2],
                        'D': row.split(',')[3]
                        })


            print('Finished Inserting into TableName: ' + tableName)
        except dynamodb_client.exceptions.ResourceNotFoundException as tableNotFoundEx:
            return ('ERROR: Unable to locate DynamoDB table: ', tableName)


    except KeyError as dynamoDBKeyError:
        msg = 'ERROR: Need DynamoDB Environment Var: DB_TABLE_NAME'
        print(dynamoDBKeyError)
        return msg;

    log.info("Finished Inserting into TableName: " + tableName)

    # Send Notificaiton to SNS
    try :
        topicName = os.environ['SNS_TOPIC_ARN']
        print('*SNS TopicName*=', topicName)
        log.info("TopicName: " +  topicName)

        sns_client = boto3.client('sns')

        sns_client.publish(
            TopicArn = topicName,
            Message = "Vehicle Master data updated in DynamoDB!"
        )

        print('Generated new SNS message, ID: ' + recordId)
        log.info("Generated new SNS message, Topic: " + topicName)

    except KeyError as snsKeyError:
        msg = 'ERROR: Need SNS Environment Var: SNS_TOPIC_NAME'
        print(snsKeyError)
        return msg;

    # return
    return {
        "statusCode": 200,
        "body": json.dumps('Updated to DDB!')
    }

我不确定-错误在哪里:

0 个答案:

没有答案