AWS中lambda与DynamoDB的集成

前言:我在整个集成过程中,存在最大的问题有两个,

  1. 没有考虑到lambda函数的权限,即对DynamoDB或者其他如Kinesis的权限授权,导致无法写入或者读取。

2.最初使用了异步方式调用,导致无法写数据到DynamoDB,把代码改成同步调用即可

创建Lambda函数

javascript 复制代码
'use strict'
console.log('Loading function');

var aws = require('aws-sdk');
var docClient = new aws.DynamoDB.DocumentClient({region: 'ap-southeast-1'});


exports.handler = function(event, context,callback)  {
    var records = event.Records;
    if(records){

        records.forEach(function(record){
            //console.log('record:',record);
            //var payload = new Buffer(record.kinesis.data,'base64').toString('ascii');
            var payload = Buffer.from(record.kinesis.data, 'base64').toString('ascii');
           
            console.log('Decode payload:',payload);
           
           var params ={
                Item:{
                    date:Date.now(),
                    message:payload
                },
                TableName:"Lambda-Dynamo-Write-Read-China"
            };
            if(docClient){
                console.log('docClient is not null');
                console.log('params date:',params.Item.date);
                //         //await ddb.put(params).promise();
                //await ddb.put(params).promise();
                docClient.put(params,function(err,data){
                    if(err){
                        console.log("Fail to Write into AWS DynamoDB");
                        callback(err,null);
                        
                    }else{
                        console.log("Successfully write item into AWS DynamoDB")
                        callback(null,data)
                    }
                    
                });
            }else{
                console.log('docClient is null');
            }
            
        });
        
    }else{
        console.log('records is empty');
    }
    
};

创建好之后保存,然后进行部署(deploy)

然后在IAM中,对相应的角色进行授权(lambda-kinsis-guangzhou-role-xxx)这个角色名是创建lambda自动生成的,在上面增加相应的权限即可。

创建触发器

创建DynamoDB 的表

创建好后,给表增加属性字段

注意:只需要增加一个分区字段date即可,message字段,在Lambda方法中,作为入参传入即可

创建Kinesis

在本地使用aws-cli发送消息报文

在DynamoDB如果能看到发送的数据,即集成成功

相关推荐
byoass10 小时前
自动化任务系列之五:PDF批量转换+自动清理——文件格式规范化工作流
网络·人工智能·安全·云计算
Flynt11 小时前
AWS WorkMail + App Runner:服务退役时的迁移检查清单
app·aws
byoass11 小时前
自动化任务系列之六:自动整理文件——按时间/关键字分类归档实战
运维·网络·安全·自动化·云计算
zjeweler12 小时前
阿里云服务器利用宝塔搭建个人博客网站
服务器·阿里云·云计算
easy_coder12 小时前
《工程化视角下的Prompt设计与迭代:云诊断与CICD变更风控中的实践》
人工智能·云计算·prompt
byoass14 小时前
自动化任务系列之二:批量建目录树——Excel模板驱动千人项目初始化
运维·网络·安全·自动化·云计算
小夏子_riotous15 小时前
Docker学习路径——9、Docker 网络深度解析:从默认网络到自定义网络实战
linux·运维·网络·docker·容器·centos·云计算
同聘云16 小时前
阿里云国际站服务器DNS服务器设置成什么?服务器dns怎么填写?
服务器·阿里云·云计算·云小强
牛奶咖啡1316 小时前
Docker容器实践——使用docker-compose部署wordpress应用与prometheus监控
docker·云计算·docker-compose·一键部署wordpress应用·一键部署prometheus·生产环境套上nginx原因·使用nginx反向代理优势
TG_yunshuguoji16 小时前
腾讯云代理商:腾讯云怎么一键部署Hermes?
人工智能·云计算·腾讯云·hermes agent·hermes