AWS Lambda将数据保存在DynamoDB中

在本教程中,我们将看到如何使用AWS Lambda将数据保存在Dynamo DB中。

这是必需的步骤:

在Dynamo数据库中创建一个名为Employee的表
–创建一个AWS Lambda函数,该函数可以使用Dynamo数据库中的Employee POJO保存雇员的名字和姓氏
–创建一个策略,该策略将仅对DynamoD B的Employee表提供读/写访问权限 –将策略附加到角色 –在AWS Lambda控制台中以jar的形式上载AWS Lambda函数的代码 –将在步骤4中创建的角色附加到AWS Lambda –运行测试事件以调用AWS Lambda以将Employee数据保存在Dynamo DB中

1.在Dynamo数据库中创建一个名为Employee的表

1.1要在Dynamo DB中创建表,请登录AWS控制台并在服务中搜索Dynamo DB,或者您可以在Database下找到DynamoDB服务。单击Dynamo DB,您将看到以下屏幕。

1.2要创建一个Employee表,单击“ Create table”按钮,您将看到以下屏幕。 输入表名称为“ Employee”,分区键为“ emp_id”,然后单击“ Create”按钮。

如下面的屏幕快照所示,它将为您创建Employee表。

只需单击项目选项卡,您就可以看到带有empId列的表已创建。

2.创建一个AWS Lambda函数,该函数可以使用Dynamo数据库中的Employee POJO保存雇员的名字和姓氏

Pom.xml中的依赖项:

<dependency><groupId>com.amazonaws</groupId><artifactId>aws-lambda-java-core</artifactId><version>1.1.0</version>
</dependency>
<dependency><groupId>com.amazonaws</groupId><artifactId>aws-java-sdk-dynamodb</artifactId><version>1.11.0</version>
</dependency>

Java代码:

package com.blogspot.javasolutionsguide.handler;import com.amazonaws.regions.Region;
import com.amazonaws.regions.Regions;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.PutItemOutcome;
import com.amazonaws.services.dynamodbv2.document.Table;
import com.amazonaws.services.dynamodbv2.document.spec.PutItemSpec;
import com.amazonaws.services.lambda.runtime.Context;
import com.amazonaws.services.lambda.runtime.RequestHandler;
import com.blogspot.javasolutionsguide.request.Employee;
import com.blogspot.javasolutionsguide.response.Response;public class SaveEmployeeHandler implements RequestHandler{private DynamoDB dynamoDb;private String DYNAMO_DB_TABLE_NAME = "Employee";private Regions REGION = Regions.US_EAST_1;@Overridepublic Response handleRequest(Employee personRequest, Context context) {this.initDynamoDbClient();persistData(personRequest);Response personResponse = new Response();personResponse.setMessage("Message Saved Successfully");return personResponse;}private void initDynamoDbClient() {AmazonDynamoDBClient client = new AmazonDynamoDBClient();client.setRegion(Region.getRegion(REGION));this.dynamoDb = new DynamoDB(client);}private PutItemOutcome persistData(Employee employee) {Table table = dynamoDb.getTable(DYNAMO_DB_TABLE_NAME);PutItemOutcome outcome = table.putItem(new PutItemSpec().withItem(new Item().withNumber("empId", employee.getEmpId()).withString("firstName", employee.getFirstName()).withString("lastName", employee.getLastName())));return outcome;}
}

3.创建一个策略,该策略将仅对DynamoDB的Employee表提供读/写访问权限,并附加一个Role

我们需要提供对AWS Lambda函数的访问权限以读取/写入Dynamo DB表。为此,我们将首先创建一个Polciy,然后将该策略附加到Role。

要创建新策略,请依次转到“服务”和“ IAM”。

单击“访问管理”下的“策略”,您将看到以下屏幕。

单击创建策略,您将看到以下屏幕:

单击“选择服务”,然后在搜索框中键入DynamoDB。

选择Dynamo DB,然后在“访问级别”部分中选择GetItem和PutItem。

选择资源。

单击您的Dynamo Db表所在的“添加ARN.Fill区域”,然后输入表名,然后单击“添加”。

单击“查看策略”,然后输入要提供给策略的名称,并输入有关此策略的描述,然后单击“创建策略”。

4.创建一个角色并将策略附加到该角色

转到IAM服务->角色,单击创建角色按钮,您将看到以下屏幕。

选择AWS服务作为受信任实体。 这是您要为其分配角色的实体,因为我们想将此角色分配给Lambda函数(仅AWS服务),因此我们选择了AWS服务。 同样在“选择用例”中,选择Lambda,然后单击“下一个权限”。 您将看到以下屏幕。

现在,在“筛选器策略”中,键入您刚在步骤2中创建的策略名称(DynamoDBEmployeeTblAccess)

在下一个屏幕上,单击“ Next:Tags”按钮,然后单击“ Next:Review”按钮。在下一个屏幕上,在“角色名称”中输入名称“ DynamoDBEmployeeTblAccess”。 添加角色描述。

单击“创建角色”按钮,您将看到以下成功消息:

5.在AWS Lambda控制台中以jar的形式上传AWS Lambda函数的代码

本教程的所有代码都已放入我的Git存储库中。 链接在本教程的结尾给出。

因此,您可以将该代码导入您的工作区中,然后进行maven构建,这将为您创建jar,然后按照我之前的教程进行操作
如何使用Java创建Aws Lambda函数 ,您可以轻松地将jar上传到AWS lambda控制台。

6.将在步骤4中创建的角色附加到AWS Lambda

在Lambda的“权限”部分中,选择“附加现有角色”,然后从下拉列表中选择在步骤4中创建的角色,然后单击“保存”。

7.运行Test事件以调用AWS Lambda将Person数据保存在Dynamo DB中

成功上传jar之后,转到“选择测试事件”下拉菜单,然后单击“配置测试事件”。

您将看到包含以下数据的屏幕。输入事件名称为“ HelloWorldEvents”并替换以下数据

{
"key1": "value1",
"key2": "value2",
"key3": "value3"}with below Json :
{
"empId": 1,
"firstName": "Gaurav",
"lastName": " Bhardwaj"}
/pre>

Click on "save" button and then on "Test" button.

You should be able to see following screen.

现在转到您的Dynamo Db服务并打开Employee表,然后单击Start search按钮,您应该可以看到以下记录:

您可以在GitHub中找到本教程的所有代码。

总结和几点要点:

因此,在本教程中,我们看到了

-如何使用Lambda函数将数据保存在Dynamo DB中。

-我们仅创建了empId属性,并且在保存Employee对象时Dynamo Db会自动为我们创建其余属性,因为它具有firstName和surName属性,并且POJO的名称与表的名称匹配。 DynamoDB控制台也具有所有三个属性的表。

-如果我们再次尝试保存相同的对象(具有相同的ID),那么它将只是覆盖现有的对象,因此不会有任何异常。

翻译自: https://www.javacodegeeks.com/2020/03/aws-lambda-to-save-data-in-dynamodb.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/340143.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java list 取几个字段组装成map_24道Java各类常见问题整理

(1) JSP学了EL表达式就行了吧&#xff0c;还需要深入么&#xff1f;还有spring现在学5就行了吧&#xff1f;总觉得类与对象这里好难&#xff0c;理解不来(2) 我想问问在校生需要学习JAVA到哪种程度&#xff0c;然后再学学数据结构和算法能达到校招面试的水平(3) 静态变量与实例…

Maven硒测试自动化教程

在进行测试自动化项目时&#xff0c;您需要与之关联的所有Selenium依赖项。 通常&#xff0c;这些依赖项是在项目生命周期中手动下载和升级的&#xff0c;但是随着项目规模的扩大&#xff0c;管理依赖项可能会非常困难。 这就是为什么需要构建自动化工具&#xff08;例如Maven&…

java确认rabbitmq_RabbitMQ 消息确认机制

生产端 Confirm 消息确认机制消息的确认&#xff0c;是指生产者投递消息后&#xff0c;如果 Broker 收到消息&#xff0c;则会给我们生产者一个应答。生产者进行接收应答&#xff0c;用来确定这条消息是否正常的发送到 Broker &#xff0c;这种方式也是消息的可靠性投递的核心保…

hadoop源码分析_Spark2.x精通:Job触发流程源码深度剖析(一)

&#xff0c; 一、概述 之前几篇文章对Spark集群的Master、Worker启动流程进行了源码剖析&#xff0c;后面直接从客户端角度出发&#xff0c;讲解了spark-submit任务提交过程及driver的启动&#xff1b;集群启动、任务提交、SparkContext初始化等前期准备工作完成之后&am…

如何在Java中将String转换为int

在本教程中&#xff0c;我们将看到将Java中的String转换为int&#xff08;或Integer&#xff09;的各种方法。 您可以使用以下任何一种方式&#xff1a; –使用Integer.parseInt&#xff08;string&#xff09; –使用Integer.valueof&#xff08;string&#xff09; –使用…

jboss 程序位置_介绍JBoss BPM Suite安装程序

jboss 程序位置本周&#xff0c;我们想向您介绍JBoss BRMS和JBoss BPM Suite产品随附的一个鲜为人知的安装程序组件。 请注意&#xff0c;当前所有的演示项目都要求您下载JBoss BPM Suite可部署的eap zip产品文件和JBoss EAP 6.1.1 zip产品文件。 展望未来&#xff0c;我们将迁…

java换成中文_如果我们的编程替换成中文会变成怎样?

首先大概的看一下中文编码&#xff1a;你以为会写中文就会编程吗&#xff1f;这就像你以为会写汉字就会写出好文章一样。编程是和机器沟通&#xff0c;因此要用机器的语言而不是人类的语言。最早的程序就是0和1的数字&#xff0c;不是中文也不是英文。以前的程序员&#xff0c;…

高等数学公式大全_高中物理知识思维导图大全,赶紧收藏!

物理作为理综的重中之重&#xff0c;物理的学习一直是广大考生的难点。如何快捷高效的掌握物理知识点是高考复习的重点之一&#xff0c;根据高中物理三年知识点用思维导图的方式&#xff0c;来助大家掌握物理知识点。运动的描述 重力 基本相互作用 相互作用 牛顿运动定律 力的合…

go环境搭建_学习的golang第一步,搭建我们运行的环境,go! go! go

这是Golang教程系列中的第一个教程。本教程介绍了Go&#xff0c;并讨论了选择Go优于其他编程语言的优势。我们还将学习如何在Mac OS&#xff0c;Windows和Linux中安装Go。介绍Go也称为Golang是由Google开发的一种开源&#xff0c;编译和静态类型的编程语言。创造Go的关键人物是…

如何在Java中将数组转换为列表

你好朋友&#xff0c; 在本教程中&#xff0c;我们将学习将数组转换为List的各种方法。 package com.blogspot.javasolutionsguide;import com.google.common.collect.Lists; import org.apache.commons.collections4.CollectionUtils;import java.util.ArrayList; import ja…

html5网页制作代码_HTML5的网页设计教程

关注小编&#xff0c;教你如何制作网页HTML5是超文本标记语言(HyperText Markup Language)的第五代版本&#xff0c;它是书写网页代码的一种规范、一种标准。它通过标记符号来标记要显示的网页中的各个部分。浏览器根据这个标准显示其中的内容(如&#xff1a;文字如何处理&…

aop+注解 实现对实体类的字段校验_SpringBoot实现通用的接口参数校验

来自&#xff1a;掘金&#xff0c;作者&#xff1a;cipher链接&#xff1a;https://juejin.im/post/5af3c25b5188253064651c76原文链接&#xff1a;http://www.ciphermagic.cn/spring-boot-aop-param-check.html本文介绍基于Spring Boot和JDK8编写一个AOP&#xff0c;结合自定义…

java基础分享_一、java基础教程

1、java是一门比较纯粹的面向对象编程语言&#xff0c;所以java的所有代码都必须写在类的内部。1.1 java的可执行文件后缀名是".java"&#xff0c;例如HelloWorld.java&#xff0c;并且每个可执行文件内部&#xff0c;必须有且仅有一个public公共类/公共接口/公共抽象…

Spring Boot自定义横幅生成

每当我们启动Spring Boot应用程序时&#xff0c;都会显示如下所示的文本消息。 这称为横幅。 现在&#xff0c;如果我们可以创建一个特定于我们的Spring Boot应用程序的自定义横幅并使用它代替默认的Spring Boot横幅&#xff0c;那将不是一件很棒的事。 有很多方法可以生成和使…

java等待_Java学习:等待唤醒机制

等待唤醒机制线程的状态NEW 至今尚未启动的线程处于这种状态RUNNABLE 正在Java虚拟机中执行的线程处于这种状态BLOCKED 受阻塞并等待某个监视器锁的线程处于这种状态WAITING 无限期的等待另一个线程来执行某一待定操作的线程处于这种状态TIMED_WAITNG 等待另一个线程来执行取…

游戏ai 行为树_游戏AI –行为树简介

游戏ai 行为树游戏AI是一个非常广泛的主题&#xff0c;尽管有很多资料&#xff0c;但我找不到能以较慢且更易理解的速度缓慢介绍这些概念的东西。 本文将尝试解释如何基于行为树的概念来设计一个非常简单但可扩展的AI系统。 什么是AI&#xff1f; 人工智能是参与游戏的实体表现…

java构造器_Java构造器就是这么简单!

前言理解构造器之前&#xff0c;首先我们需要了解Java中为什么要引入构造器&#xff0c;以及构造器的作用。在很久之前&#xff0c;程序员们编写C程序总会忘记初始化变量&#xff08;这真的是一件琐碎但必须的事&#xff09;&#xff0c;C引入了 构造器(constructor) 的概念&am…

JavaFX技巧32:需要图标吗? 使用Ikonli!

动机 自2013年以来&#xff0c;我一直在编写JavaFX应用程序和库的代码&#xff0c;它们的共同点是&#xff0c;我需要找到可以用于它们的良好图标/图形。 作为前Swing开发人员&#xff0c;我首先使用图像文件&#xff0c;GIF或PNG。 通常&#xff0c;我会从IconExperience&…

java应用部署docker_Docker部署JavaWeb项目实战

摘要&#xff1a;本文主要讲了怎样在Ubuntu14.04 64位系统下来创建一个执行Java web应用程序的Docker容器。一、下载镜像、启动容器1、下载镜像先查看镜像docker images记住这个Image ID&#xff0c;下面我们启动容器须要用到它。假设看到以上输出&#xff0c;说明您能够使用“…

如何用Java创建不可变的Map

你好朋友&#xff0c; 在本教程中&#xff0c;我们将看到如何用Java创建不可变的Map。 –不可变的类或对象是什么意思&#xff1f; –什么是不可变地图&#xff1f; –如何在Java中创建不可变的Map&#xff1f; 不变的类或对象是什么意思&#xff1f; 不可变的类或对象是创…