- AWS Lambda 教程
- AWS Lambda - 主页
- AWS Lambda - 概述
- AWS Lambda - 环境设置
- AWS Lambda - 简介
- 构建 Lambda 函数
- NODEJS 中的函数
- Java 中的函数
- Python 中的函数
- Go 中的函数
- C# 中的函数
- 配置 Lambda 函数
- 使用 AWS 控制台创建和部署
- 使用 AWS CLI 创建和部署
- 使用无服务器框架创建和部署
- AWS 执行和调用 Lambda 函数
- 删除 Lambda 函数
- 使用 Amazon API Gateway
- 使用 Amazon S3 的 Lambda 函数
- 使用 Amazon DynamoDB 的 Lambda 函数
- 具有预定事件的 Lambda 函数
- 带有 Amazon SNS 的 Lambda 函数
- 带有 CloudTrail 的 Lambda 函数
- 使用 Amazon Kinesis 的 Lambda 函数
- 具有自定义用户应用程序的 Lambda 函数
- AWS Lambda@Edge 与 CloudFront
- 使用 Cloudwatch 进行监控和故障排除
- AWS Lambda - 其他示例
- AWS Lambda 有用资源
- AWS Lambda - 快速指南
- AWS Lambda - 有用的资源
- AWS Lambda - 讨论
使用 AWS 控制台创建和部署
我们可以创建 Lambda 函数并在 AWS 控制台中对其进行测试。本章详细讨论这一点。为此,您必须遵循此处给出的步骤并观察给出的相应屏幕截图 -
步骤1
登录 AWS 控制台https://aws.amazon.com/console/。现在,您将被重定向到显示 AWS 服务的屏幕。
第2步
现在,单击上面突出显示的Lambda服务。这将重定向到创建函数,如下所示 -
步骤3
现在,单击创建函数并输入函数的详细信息。然后您可以看到如下所示的屏幕 -
步骤4
您可以通过选择您选择的语言来编写代码。如果选择的选项是内联编辑代码,则必须在编辑器中编写代码。其他可用选项如下 -
步骤5
完成后,您需要保存右上角按钮的更改,如下所示 -
步骤6
现在,单击“测试”按钮。这给出了 Lambda 函数执行的所有详细信息,如下所示 -
步骤7
index.js的代码如下 -
exports.handler = (event, context, callback) => { // TODO implement callback(null, 'Lambda test'); };
这将调用回调函数,结果可能是错误或成功。成功后,您将看到一条Lambda 测试消息;如果出错,它将传递 null。
步骤8
Lambda 函数的角色详细信息是配置的一部分,显示如下 -
步骤9
现在,您可以根据需要更新角色并保存 Lambda 函数。然后,lambda 函数的内存和超时详细信息显示如下 -
步骤10
现在,我们需要向 Lambda 函数添加触发器,以便它在事件发生时执行。触发器详细信息显示在 AWS Lambda 函数屏幕的开头,如下所示 -
您可以从中选择希望触发 Lambda 函数的触发器。当您选择触发器时,必须添加触发器的配置详细信息。
例如,对于 S3 上的触发器,要添加的配置详细信息如下 -
第11步
现在,选择您想要触发的存储桶。事件类型具有以下详细信息 -
步骤12
对于触发器,您还可以提及前缀类型文件或文件模式,Lambda 必须是触发器。详细信息如图所示 -
步骤13
现在,填写触发器所需的详细信息,然后单击“添加”按钮。保存要添加的触发器的 Lambda 函数。保存函数会部署详细信息,从现在开始,只要将文件添加到 S3 存储桶,Lambda 就会获取触发。
观察以下屏幕截图,其中显示 S3 触发器已添加到 AWS Lambda -
第14步
现在,让我们使用 S3 示例事件来测试 Lambda 函数。相同的代码如下所示 -
Amazon S3 Put 示例事件
{ "Records": [{ "eventVersion": "2.0", "eventTime": "1970-01-01T00:00:00.000Z", "requestParameters": { "ExampleIPAddress": "127.0.0.1" }, "s3": { "configurationId": "testConfigRule", "object": { "eTag": "0123456789abcdef0123456789abcdef", "sequencer": "0A1B2C3D4E5F678901", "key": "HappyFace.jpg", "size": 1024 }, "bucket": { "arn": bucketarn, "name": "Examplebucket", "ownerIdentity": { "principalId": "Example" } }, "s3SchemaVersion": "1.0" }, "responseElements": { "x-amz-id-2": "Example123/5678abcdefghijklambdaisawesome/mnopqrstuvwxyzABCDEFGH", "x-amz-request-id": "Example123456789" }, "awsRegion": "us-east-1", "eventName": "ObjectCreated:Put", "userIdentity": { "principalId": "Example" }, "eventSource": "aws:s3" }] }
您必须使用以下命令来获取从 S3 put 事件上传的文件的详细信息 -
event.Records[0].s3.object.key //will display the name of the file
您必须使用以下命令来获取存储桶名称 -
event.Records[0].s3.bucket.name //will give the name of the bucket.
您必须使用以下命令来获取 EventName -
event.Records[0].eventName // will display the event name
步骤15
现在,让我们更新 AWS Lambda 代码以打印 S3 详细信息,如下所示 -
exports.lambdahandler = (event, context, callback) => { callback(null, "Bucket name: "+event.Records[0].s3.bucket.name+" File name:"+event.Records[0].s3.object.key ); };
第16步
保存更改。单击测试并输入 S3 示例事件 -
步骤17
现在单击测试,您可以看到输出,如图所示 -
步骤18
要使用 S3 AWS 服务在 S3 上测试触发器,请在 S3 存储桶中上传文件:测试存储桶触发器。更新与 Lambda 一起使用的角色,以获取 S3 和 SES 策略(发送邮件)的权限。这将更新 AWS Lambda 代码以发送邮件以查看触发器的工作情况 -
更新后的 AWS Lambda 代码如下所示 -
var aws = require('aws-sdk'); var ses = new aws.SES({ region: 'us-east-1' }); exports.lambdahandler = function(event, context, callback) { var eParams = { Destination: { ToAddresses: ["coxxxxxxx@gmail.com"] }, Message: { Body: { Text: { Data: "Bucket name: "+event.Records[0].s3.bucket.name+" File name:"+event.Records[0].s3.object.key } }, Subject: { Data: "S3 and AWS Lambda" } }, Example: "coxxxxxx@gmail.com" }; console.log('===SENDING EMAIL==='); var email = ses.sendEmail(eParams, function(err, data) { if (err) console.log(err); else { console.log("===EMAIL SENT==="); console.log("EMAIL CODE END"); console.log('EMAIL: ', email); context.succeed(event); callback(null, "email is send"); } }); };
相应的屏幕截图如下所示 -
步骤19
现在,上传文件并检查 AWS Lambda 代码中提供的邮件 ID -