AWS Lambda函数实战
实战效果:开发一个函数,它会关注事件中的某个名字,并返回“Hello<名字>!”。如果输入事件没有提供名字,则函数返回一个更加通用的问候语“Hello World!”。
AWS Lambda函数实战
- AWS Lambda函数实战
- 一、创建一个新的AWS Lambda函数
- 二、使用步骤
- 1.编写函数
- 2.测试函数
- 安装和配置AWS CLI
AWS Lambda接口可以通过AWS命令行或可在服务器、浏览器及移动设备上运行的AWS软件开发包(SDK)来调用。
一、创建一个新的AWS Lambda函数
首先要在浏览器中访问AWS的控制台https://console.aws.amazon.com/。登录后,在Compute区域选择Lambda,从顶端菜单的右侧选择AWS Region(通常选择距离你较近的区域来降低网络延时),然后在弹出页面点击“Get Started Now”。如果这不是所选区域中的第一个函数,你不会看到欢迎页面,而会看到一组已经存在函数的代码清单。这种情况下,直接点击“Create a Lambda Function”即可。
二、使用步骤
1.编写函数
把选项设置为“Edit code inline”,根据你所选择的运行时环境在Web控制台的编辑器中输入以下代码。以下代码分别以Node.js实现了函数的逻辑。
代码如下(示例):
·在Node.js中,我们使用标准的Node.js编程模型中的callback结束函数。在本例中,使用callback(null,data)成功结束函数,并返回greeting字符串对象。如果callback第一个参数不是null,则表示函数遇到执行错误返回,如callback(error)。
·AWS Lambda的函数是在一个没有任何可视化信息的“无头”环境下执行的。因此,所有运行时都实现了可以方便地向Amazon CloudWatch写入集中日志的方式。Amazon CloudWatch是一种监控和日志服务,可用来管理应用程序的指标、警告和日志,以及应用程序中用到的AWS服务。在Node.js环境下,任何用console.log()写出来的东西都被重定向到CloudWatch Logs;而在Python中,则是重定向print输出的任何内容。
·初始化完成后,函数获取作为事件输入的信息和调用的上下文——两者都是运行时的原生格式:Node.js中采用JavaScript对象,Python中采用字典类型。这样的函数格式可以用于执行所有的调用,我们可以以后再做进一步的配置。
·函数的逻辑非常简单:如果输入事件中包含了“name”键值,name信息会被置入greeting字符串,否则就输出默认的“Hello World!”。
2.测试函数
在控制台的左上角点击测试按钮,然后需要为所有的测试准备一个测试事件。当调用Lambda函数时,使用JSON格式表述的事件对象信息会被实际的函数运行时转化为它们各自的原生对象或类型,如JavaScirpt对象或Python中的Dict类型。
测试界面的下拉菜单有一些样板的事件,这些事件在订阅了如Amazon S3或Amazon DynamoDB等标准资源时会被接收到。我们的函数使用自定义格式的事件,所以这些样板事件模版暂时用不到。你需要编辑事件的信息,为函数提供name作为输入。
{“name”:“Hello wang!”}
点击窗口中的“Save and test”,函数会使用你所编辑的事件信息作为输入而被调用。执行的结果会显示在窗口页面的底部。显示的结果包括了函数的返回值、日志和执行情况的汇总:如实际的执行时间,计费的时间(以100ms为单位),内存使用量。所有这些信息同时也以原始日志的方式被输出。
如果一切正常,你将会在执行结果中看到“Hello wang!”。现在,你已经成功执行了第一个Lambda函数!
安装和配置AWS CLI
为了安装和配置AWS CLI命令行工具,可参照AWS网站http://aws.amazon.com/cli/所提供的针对Windows、Mac和Linux的安装指导。
建议从文档中的Getting Started链接开始,为CLI创建一个AWS IAM用户。以下是安全策略:
AWSLambdaFullAccess
AmazonAPIGatewayAdministrator
AmazonCognitoPowerUser
当使用aws configure命令配置CLI时,需要将当前的AWS region设为默认值。否则,需要在每一个AWS CLI命令中通过–region的方式显式指定每条命令执行所针对的region。
同时也建议你启用文档中所描述的CLI自动命令完成功能。为了测试AWS CLI的安装和配置是否正确,你可以尝试执行aws lambda list-functions命令来获取你账户下已经创建的AWS Lambda函数的一个列表,连同每个函数的配置信息,如内存大小、超时、执行角色等等。
CLI的默认输出格式是JSON,但是在初始配置CLI时可以使用–output选项进行更改。为了调用我们刚才创建的函数,在命令行使用如下的语法(请注意JSON事件在单引号中):警告 如果你使用Windows下的AWS CLI来执行Lambda函数调用,需要把上述的单引号更改为双引号,并重复一次[1]。
例如,--payload'<JSON event>'
应该更改为--payload"{""name"":""wang""}"
。
函数的输出被写入一个本地文件。例如,如果要问候“wang”,就在命令行输入如下的命令:警告 如果在配置AWS CLI时没有指定你创建和运行AWS Lambda的region的话,你必须在命令结尾通过–region参数指定,否则上述的命令会报错。
在命令行执行如下命令,可以测试没有name作为输入时函数的执行结果,返回的信息是Hello World!