一推网

当前位置: 首页 > 知识问答 > AWS 控制台创建和部署Lambda 函数

知识问答

AWS 控制台创建和部署Lambda 函数

2025-09-22 02:59:05 来源:互联网转载

我们可以创建 Lambda 函数并在 AWS 控制台中对其进行测试。本章对此进行了详细讨论。为此,您必须按照此处给出的步骤操作并观察给出的相应屏幕截图-

免绑卡注册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 函数的Role详细信息是配置的一部分,如下所示-

步骤 9

现在,您可以根据需要更新角色并保存 Lambda 函数。然后,lambda 函数的内存和超时详细信息如下所示-

步骤 10

现在,我们需要为 Lambda 函数添加触发器,以便它在事件发生时执行。触发器详细信息显示在 AWS Lambda 函数屏幕的开头,如下所示-

从中,您可以选择希望触发 Lambda 函数的触发器。选择触发器时,必须添加触发器的配置详细信息。

例如,对于 S3 上的触发器,要添加的配置详细信息如下-

第 11 步

现在,选择您想要触发的存储桶。事件类型具有以下详细信息-

第 12 步

对于触发器,您还可以提及前缀类型文件或文件模式,Lambda 必须是触发器。详情如图所示-

第 13 步

现在,填写触发器所需的详细信息,然后单击添加按钮。保存要添加的触发器的 Lambda 函数。保存该函数会部署详细信息,从现在开始,任何时候文件都是添加到 S3 存储桶后,Lambda 将被触发。

观察以下屏幕截图,其中显示了添加到 AWS Lambda 的 S3 触发器-

第 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 步

保存更改。点击Test并输入 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-


海外服务器免费测试

aws管理控制台

上一篇:域名注册多久才能交易?

下一篇:俄罗斯网站设计的未来趋势,探索技术与艺术的无限可能