使用 Lambda 函数从 So DynamoDB 解析和加载数据

碧海醫心
发布: 2025-01-06 20:17:31
原创
758人浏览过

本文介绍如何使用aws lambda函数将s3存储桶中的json数据加载到dynamodb表中。

先决条件:

  1. 拥有向S3上传对象的权限。
  2. 拥有S3和DynamoDB权限的Lambda执行角色。

架构和组件:

本方案使用三个AWS服务:

  1. S3存储桶: 作为可扩展、安全、高性能的对象存储服务,用于存储数据。
  2. Lambda函数: 无服务器计算服务,用于运行代码并处理数据,无需管理基础设施。支持多种编程语言,易于设置。
  3. DynamoDB: 无服务器NoSQL数据库,用于存储Lambda函数处理后的数据。

使用 Lambda 函数从 So DynamoDB 解析和加载数据

工作流程:

  1. 用户通过控制台或CLI使用PutObject API将JSON文件上传到S3存储桶。
  2. 文件上传成功后,触发S3事件,调用Lambda函数进行数据加载和处理。
  3. Lambda函数处理数据并将其加载到DynamoDB表中。

实施步骤:

以下步骤详细说明如何部署和配置上述架构:

1. 创建Lambda函数:

  • 函数名称:parserdemo
  • 运行时:Python 3.1x (或其他支持的运行时)

其他设置保持默认值。创建函数后,修改超时配置和执行角色,如下所示:

使用 Lambda 函数从 So DynamoDB 解析和加载数据使用 Lambda 函数从 So DynamoDB 解析和加载数据

以下Python代码实现数据处理逻辑:

怪兽AI数字人
怪兽AI数字人

数字人短视频创作,数字人直播,实时驱动数字人

怪兽AI数字人 44
查看详情 怪兽AI数字人
<code class="python">import json
import boto3

s3_client = boto3.client('s3')
dynamodb = boto3.resource('dynamodb')

def lambda_handler(event, context):
    bucket_name = event['Records'][0]['s3']['bucket']['name']
    object_key = event['Records'][0]['s3']['object']['key']
    print(f"Bucket: {bucket_name}, Key: {object_key}")

    response = s3_client.get_object(Bucket=bucket_name, Key=object_key)
    json_data = response['Body'].read()
    string_formatted = json_data.decode('UTF-8')
    dict_format_data = json.loads(string_formatted)

    table = dynamodb.Table('DemoTable')
    if isinstance(dict_format_data, list):
        for record in dict_format_data:
            table.put_item(Item=record)
    elif isinstance(dict_format_data, dict):
        table.put_item(Item=dict_format_data)
    else:
        raise ValueError("Unsupported Format")
</code>
登录后复制

2. 创建S3存储桶:

桶名称:使用唯一名称。其他设置保持默认值。将创建的S3存储桶作为触发器添加到Lambda函数:

使用 Lambda 函数从 So DynamoDB 解析和加载数据使用 Lambda 函数从 So DynamoDB 解析和加载数据

3. 创建DynamoDB表:

  • 表名称:DemoTable
  • 分区键:userid
  • 表设置:自定义
  • 容量模式:预配置

为了降低成本,将预配置容量单位设置为较低的读/写单位(例如1或2个单位)。

使用 Lambda 函数从 So DynamoDB 解析和加载数据使用 Lambda 函数从 So DynamoDB 解析和加载数据

完成设置后,上传文件到S3进行测试。您可以在DynamoDB表中查看已创建的项目和上传的记录。 Lambda函数的CloudWatch日志和DynamoDB项目如下所示:

使用 Lambda 函数从 So DynamoDB 解析和加载数据使用 Lambda 函数从 So DynamoDB 解析和加载数据

参考:

  • S3 API
  • DynamoDB API
  • Boto3 for AWS services

希望此指南对您有所帮助。如有任何疑问,请提出。

以上就是使用 Lambda 函数从 So DynamoDB 解析和加载数据的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号