强大的AWS lambda

AWS强大的lambda

自从几年前换工作后,我所参与的项目一直都是基于AWS云服务的架构,我慢慢对serverless的相关基础建设有了一定了解和实践经验。其中lambda是我心中最强大的serveless服务,是很好的高并发业务解决方案。

  1. 什么是lambda
    lambda是AWS提供的一种无服务器的计算服务,根据请求流量自动扩展应用服务,
  • 按需付费

    因为是无服务器,所以无需提前准备(租用)好物理服务器。按照计算次数(请求次数)来收取费用,非常节省运维成本。

  • 支持高并发

    目前默认对每个账号的每个region(区域)最大并发执行数是1000,也就是说如果同一秒来了1000个计算请求,那么它可以最多并发处理1000个请求。最大并发执行数可以根据实际需求进行调整和设置。

  • 事件驱动

    复制代码
    lambda可以被多种事件(event)触发执行,比如HTTP请求,数据库操作,文件上传等等。
  • 支持多种编程语言

lambda可以支持多种编程语言,比如Node.js, Python, Java, Go, Ruby以及.NET Core(C#),基本覆盖了主流编程技术,可以选择我们项目中对应实用的编程语言进行开发。特别是对NodeJS和Python的SDK最为全面,这也是很多公司选择AWS lambda的原因之一。

  1. lambda如何创建

有两种方式可以创建lambda,一种是通过AWS控制台进行创建,通过创建页面的引导进行相关设置,在线编写lambda的逻辑处理代码。另一种就是通过上传代码包,从而创建lambda。

对于代码包(通常是zip包)是有大小限制的,最大不能超过250M。所以如果你的zip包太大,可以选择将这些代码打包成镜像,然后再上传到AWS。

  1. lambda的常见实用场景

最常见的一个使用案例是文件处理后需要进一步处理的业务。例如视频网站在用户上传了原始视频后,需要对视频进行压缩,然后把压缩文件重新写入s3,并发送通知给用户,比如用邮件的方式。

那么对于这种并发量无法简单估算且处理逻辑比较清晰的场景,可以选择用lambda去完成。lambda的代码流程:

  1. s3 event去触发lambda,传递message给lambda function。

  2. lambda对message中的s3文件进行下载,然后压缩,生成新的文件。

3)lambda上传新生成的文件到s3,并写入记录到数据库。

4)lambda通过AWS简单邮件服务(SES)发送通知邮件给用户。

代码如下所示:

复制代码
const AWS = require('aws-sdk');
const ses = new AWS.SES();

exports.handler = async (event) => {
    const params = {
        Destination: {
            ToAddresses: ['recipient@example.com']
        },
        Message: {
            Body: {
                Text: {
                    Data: 'Hello, this is the email body.'
                }
            },
            Subject: {
                Data: 'Subject of the email'
            }
        },
        Source: 'sender@example.com'
    };

    try {
        const result = await ses.sendEmail(params).promise();
        console.log('Email sent:', result);
        return {
            statusCode: 200,
            body: JSON.stringify('Email sent successfully!')
        };
    } catch (error) {
        console.error('Error sending email:', error);
        return {
            statusCode: 500,
            body: JSON.stringify('Error sending email.')
        };
    }
};

Lambda还有更多实际的配置和使用案例,比如怎么和SQS、SNS服务进行集成,我会在后续的博客中继续聊。

相关推荐
亚马逊云开发者1 天前
都2026了,你的游戏服务器还在裸奔?聊聊用Player Gateway彻底隐藏IP的DDoS防护方案
aws
翼龙云_cloud1 天前
亚马逊云代理商:三步用 CloudWatch 高效监控 AWS Lambda 日志
云计算·aws·云服务器
zhojiew1 天前
关于AWS Direct Connect with Transit Gateway和Direct Connect Gateway
云计算·gateway·aws
观测云1 天前
AWS DevOps Agent 接入观测云最佳实践
aws·devops·可观测性·观测云
亚马逊云开发者4 天前
试了 8 种方式全失败后,我用双通道架构把 Kiro CLI 变成了 REST API
aws
亚马逊云开发者4 天前
两个 AI Agent 互相调用是什么体验?Kiro + OpenClaw 双协议实战,架构评审从 2 天干到 15 分钟
aws
stevenzqzq4 天前
Kotlin 语法深度拆解:从 Java 匿名内部类到极简 Lambda 完整演进
java·kotlin·lambda
亚马逊云开发者5 天前
更新个监控 Agent 要协调 200 个团队?Amazon ECS 托管守护进程终于把平台工程师从苦海里捞出来了
aws
亚马逊云开发者5 天前
5 个 Agent 协同处理金融业务,我用 Kiro + AgentCore 半天就部署上线了
aws
亚马逊云开发者5 天前
我把 Claude Code 的 Token 费砍了 70%,只用了 SageMaker + 一个路由 Hook
aws