概览
工作原理
架构图说明了使用 DynamoDB Streams 和 AWS Lambda 在 Amazon DynamoDB 中进行近乎实时的数据聚合。它可以高效计算聚合数据摘要,从而提高 DynamoDB 应用程序的性能和可扩展性。
Well-Architected 支柱
上面的架构图是按照 Well-Architected 最佳实践创建的解决方案示例。要做到完全的良好架构,您应该遵循尽可能多的 Well-Architected 最佳实践。
本指南使用 DynamoDB 流自动将更改从您的 D ynamoDB 表传输到 Lambda 。这样,您就无需构建和维护自定义数据流管道。此外,借助 Amazon CloudWatch 中的日志记录和监控,您可以快速识别和解决可能出现的任何问题。
通过使用 DynamoDB 和 Lambda,您可以受益于这些 AWS 服务中内置的强大安全功能。具体而言,DynamoDB 为静态数据提供加密,而 Lambda 则提供安全、隔离的执行环境。这些服务相结合,将有助于确保您的敏感数据不受未经授权的访问或篡改。此外,本指南遵循最小权限原则,仅向 Lambda 函数授予访问和处理 Dynam oDB 数据所需的权限,进一步加强了整体安全态势。
DynamoDB 、D ynamoDB Stre ams 和 Lambda 都是由 AWS 提供的完全托管的服务。Lambda 包括自动重试和错误处理机制等功能,用于管理处理来自流的传入数据时出现的问题。本指南中使用的所有服务都可以在高负载下自动扩展,无需停机即可修补,并且在设计上能够通过内置的重试机制实现容错。
本指南使用 DynamoDB 流来调用 Lambda 函数。利用这些服务,您可以高效地访问聚合数据,而无需进行成本高昂的表扫描,因为表扫描不仅耗费时间,还会造成系统延迟。通过 Dyn am oDB Stre ams 调用 Lambda 函数不仅可以提高数据检索效率,还可以解决扫描大型数据集时出现的潜在延迟问题,从而增强系统的整体性能。
使用 DynamoDB 和 Lambda,您只需为使用的资源付费,无需管理硬件。而且,由于 DynamoDB流是D ynamoDB 的内置功能,因此流式传输数据不会产生额外费用。与对聚合执行全表扫描相比,这种从 DynamoDB 流传输数据、通过 Lambda 函数聚合数据并将聚合数据写回 DynamoDB 的方法更具成本效益。它也比将数据流式传输到单独的数据库进行此类计算更经济实惠。
本指南通过 Lambda 的无服务器架构支持可持续的工作负载,该架构优化了资源分配并减少了维护物理硬件的需求。只有在基本 DynamoD B 表中的数据发生变化时才会调用 Lambd a 函数,从而减少了计算资源运行时间和执行次数。这种方法有助于消除维护物理基础设施的需要,提高工作负载的可持续性。
开始使用
实施资源
示例代码为起点。它经过行业验证,是规范性但不是决定性的,可以帮助您开始。
相关内容
博客
使用 Amazon DynamoDB Streams 为 Amazon DynamoDB 表构建聚合
这篇博客文章演示了如何使用 Amazon DynamoDB Streams 和 AWS Lambda 在 DynamoDB 表上执行聚合。
免责声明
示例代码;软件库;命令行工具;概念验证;模板;或其他相关技术(包括由我方人员提供的任何前述项)作为 AWS 内容按照《AWS 客户协议》或您与 AWS 之间的相关书面协议(以适用者为准)向您提供。您不应将这些 AWS 内容用在您的生产账户中,或用于生产或其他关键数据。您负责根据特定质量控制规程和标准测试、保护和优化 AWS 内容,例如示例代码,以使其适合生产级应用。部署 AWS 内容可能会因创建或使用 AWS 可收费资源(例如,运行 Amazon EC2 实例或使用 Amazon S3 存储)而产生 AWS 费用。
本指南中提及第三方服务或组织并不意味着 Amazon 或 AWS 与第三方之间存在认可、赞助或从属关系。AWS 的指南是一个技术起点,您可以在部署架构时自定义与第三方服务的集成。
找到今天要查找的内容了吗?
请提供您的意见,以便帮助我们提高页面内容的质量