使用 Amazon Lambda Web Adapter 在 Amazon Lambda 上构建 Web 应用

0547b6bdb69040bc6b2640328be4dd8e.jpeg

前言

Amazon Lambda 可结合 Amazon API Gateway 或 Application Load Balancer ,使您无需提前启动或管理服务器即可运行基于 restful API 的应用程序。此时,Amazon Lambda 将以 JSON 格式的字符串接收 http 事件,并将其转换为对象,它将事件对象以及上下文传递给 Lambda 函数。而对于已经开发好的 Web 应用程序,您可能需要做一定的改造适配才能部署到已经存在的 Amazon Lambda。

现在,我们推出了 Amazon Lambda Web Adapter 方案,您可以在不改造已有 Web 应用程序代码,使用熟悉的框架(例如 Express.js, Flask, SpringBoot 和 Laravel,或任何使用 HTTP 1.1/1.0)构建 Web 应用程序并在 Amazon Lambda 上运行它。

文章目的

本文以 nodejs express web 应用程序为例,介绍如何在不修改原有 nodejs 代码情况下,使用 Amazon Lambda Web Adapter 开发和部署一个 express web 应用部署到 Amazon Lambda。

如何工作

Amazon Lambda Web Adapter 实际上是一个 Lambda Extensions,当 docker 镜像在 Amazon Lambda 中运行时, Lambda 会自动启动 Adapter 和运行时进程。在 Amazon  Lambda Web Adapter 启动应用程序后,将每 10 毫秒对 http://localhost:8080/ 执行一次就绪检查。

它将在收到应用程序的 200 响应后,启动 Amazon Lambda 运行时客户端,并将 http 请求转发到 http://localhost:8080。这允许开发人员在不需要修改代码的情况下,将其 Web 应用程序打包为容器映像,并运行到 Amazon Lambda。

e9df66d766b58639c9c896eddea4e464.png

目前 Amazon Lambda Web Adapter 可以使用 Amazon API Gateway Rest API, HTTP API, Application Load Balancer 和 Lambda Function URLs ,接收 HTTP 请求。然后调用 Lambda function 执行代码逻辑,Amazon Lambda Adapter 将前端请求转换为 http 请求并发送到 Web 应用程序,等到 Web 应用程序处理好之后,再将 http 响应转换回 Lambda 事件响应。

244e866afd6b262b665f598c22aea4c2.png

开始使用

 Lambda Web Adapter

可以选择 Docker 镜像或者 Zip 包两种方式进行代码部署,请选择自己喜欢的方式迁移或构建您的 Web 应用程序。

前提条件:

配置和安装 sam cli:

https://docs.aws.amazon.com/zh_cn/serverless-application-model/latest/developerguide/serverless-sam-cli-install.html

option1: 

打包为 Docker 镜像或 

OCI 镜像的 Lambda 函数

可选操作:

要将 Amazon Lambda Web Adapter 与 Docker 镜像一起使用,请将您的 Web 应用程序 (http api) 打包到 Dockerfile 中,然后添加一行以将 Lambda Web Adapter 二进制文件复制到容器内的 /opt/extensions 。默认情况下,Amazon Lambda 适配器假定 Web 应用程序正在侦听端口 8080。如果不是,您可以通过配置指定端口。在 Amazon Lambda 之外运行时,Amazon Lambda Web Adapter 根本不运行。

COPY --from=public.ecr.aws/awsguru/aws-lambda-adapter:0.3.2 /lambda-adapter /opt/extensions/lambda-adapter

*左滑查看更多

ECR 公共存储库中提供了预编译的 Lambda 适配器二进制文件:public.ecr.aws/awsguru/aws-lambda-adapter。此 repo 中还提供了多架构镜像。适用于 x86_64 和 arm64 CPU 架构。

下面是一个示例 nodejs 应用程序的 Dockerfile:

FROM public.ecr.aws/docker/library/node:16.13.2-stretch-slim
COPY --from=public.ecr.aws/awsguru/aws-lambda-adapter:0.3.2 /lambda-adapter /opt/extensions/lambda-adapter
EXPOSE 8080
WORKDIR "/var/task"
ADD src/package.json /var/task/package.json
ADD src/package-lock.json /var/task/package-lock.json
RUN npm install --production
ADD src/ /var/task
CMD ["node", "index.js"]

*左滑查看更多

开始迁移 nodejs express hello world:

以下示例说明如何使用 Amazon Lambda 适配器在运行 express.js  docker应用程序,部署工具使用 SAM,因此前提条件是需要安装 Amazon cli(https://aws.amazon.com/cli/), sam cli(

https://github.com/awslabs/aws-sam-cli), docker(https://www.docker.com/products/docker-desktop), nodejs(https://nodejs.org/en/):

1.下载 example 代码到开发环境电脑,https://github.com/awslabs/aws-lambda-web-adapter/

2.进入 example 目录

cd aws-lambda-web-adapter/examples/expressjs

*左滑查看更多

3.登陆 docker,用于构建 image 镜像

aws ecr-public get-login-password --region us-east-1 | docker login --username AWS --password-stdin public.ecr.aw

*左滑查看更多

4.构建和部署

sam build
sam deploy --guided

部署时需要输入一些选项,如下图所示:

db08fd22e14ead25c7d5ea7d34533928.png

5.执行以上命令成功后,输出 API url

1bb9a9f568ae93fbcbd375083fb88ebf.png

6.进行 curl 测试访问,显示 “Hi there!”

16dca37ac6a4fbe2544a79a3bdc42b3b.png

7.清理资源

sam delete

部署过程中如果遇到报错,可以登陆控制台手动删除该 sam 对应的 cloudformation 模板,然后重新开始部署。

以上 example 代码适用于除 Amazon 托管基础镜像之外的任何基础镜像。

亚马逊云科技提供了一组可用于创建容器映像的基础映像,这些基础镜像包括运行时接口客户端,用于管理 Lambda 和函数代码之间的交互。要使用 Amazon 托管基础映像,您需要覆盖 ENTRYPOINT 以启动您的 Web 应用程序。以下 Dockfile 使用 Amazon Lambda 基础镜像:

FROM public.ecr.aws/lambda/nodejs:14
COPY --from=public.ecr.aws/awsguru/aws-lambda-adapter:0.3.1 /opt/extensions/lambda-adapter /opt/extensions/lambda-adapter
EXPOSE 8080
WORKDIR "/var/task"
ADD src/package.json /var/task/package.json
ADD src/package-lock.json /var/task/package-lock.json
RUN npm install --production
ADD src/index.js /var/task/index.js
ENTRYPOINT [ "node", "index.js" ]

*左滑查看更多

然后重新进行构建和部署。

sam build
sam deploy --guided

如果遇到测试报错,可以在 console 上找到部署的 Lambda 函数,查看 CloudWatch 日志。

option2: 

打包为 Zip 包的 Lambda 函数

(使用 Amazon 托管运行时)

Amazon Lambda Web Adapter 也适用于 Amazon 托管的 Lambda 运行时。

你需要做三件事:

1.将 Lambda Web Adapter layer 附加到您的函数。

a.x86_64:arn:aws:lambda:${AWS::Region}:753240598075:layer:LambdaAdapterLayerX86:2

b.arm64:arn:aws:lambda:${AWS::Region}:753240598075:layer:LambdaAdapterLayerArm64:2

2.将 Lambda 环境变量 AWS_LAMBDA_EXEC_WRAPPER 配置为 /opt/bootstrap。

3.将 function handler 设置为您的 Web 应用程序启动脚本。例如 sh

以下示例说明如何使用 Amazon Lambda 适配器在运行 express.js 应用程序,部署工具使用 SAM ,因此前提条件是需要安装 aws cli, sam cli, nodejs:

1.下载 example 代码到开发环境电脑,https://github.com/awslabs/aws-lambda-web-adapter/

2.进入 example 目录,cd aws-lambda-web-adapter/examples/expressjs-zip

3.构建和部署

sam build
sam deploy --guided

部署时需要输入一些选项,如下图所示:

d8cbc72ca564805e07dcfb5040784c78.png

4.执行以上命令成功后,输出 API url

f50cda3d122ffc0fd2812edb31766533.png

5.进行 curl 测试访问,显示 “Hi there!”

740d52079aa4012b82e8d64e533cca1a.png

6.清理资源

sam delete

配置说明

可以修改默认配置,使用环境变量配置就绪检查端口/路径和流量端口。这些环境变量可以在 docker 文件中定义,也可以定义为 Amazon Lambda 函数配置。

96517956f4ed539d598c51d171a678af.jpeg

REMOVE_BASE_PATH – 此环境变量的值告诉 Lambda Web Adapter 是否在 base path 下运行。例如,您可以将 API Gateway 配置为具有 /orders/{proxy+} 和 /catalog/{proxy+} 资源。每个资源都由单独的 Lambda 函数处理。因此,Lambda 内部的应用程序可能不知道 /orders 路径存在这一事实。将请求路由到应用程序时,使用 REMOVE_BASE_PATH 删除 /orders 前缀。默认为空字符串。

各种语言的Example参考

除了使用 Nodejs express 之外,如果您使用的是 Flask, SpringBoot 等 Web 框架开发 Web 程序,可以从以下各种语言的 example 示例开始,方便您使用自己熟悉的框架开发基于 Lambda 的 Web 应用程序。

Flask:

https://github.com/awslabs/aws-lambda-web-adapter/blob/main/examples/flask

Express.js:

https://github.com/awslabs/aws-lambda-web-adapter/blob/main/examples/expressjs

Express.js in Zip:

https://github.com/awslabs/aws-lambda-web-adapter/blob/main/examples/expressjs-zip

SpringBoot:

https://github.com/awslabs/aws-lambda-web-adapter/blob/main/examples/springboot

nginx:

https://github.com/awslabs/aws-lambda-web-adapter/blob/main/examples/nginx

php:

https://github.com/awslabs/aws-lambda-web-adapter/blob/main/examples/php

收益和总结

HTTP 1.1 协议是目前最主流的应用层协议,借助 Amazon Lambda Web Adapter ,我们可以在 Amazon Lambda 中开发和部署任何兼容 HTTP 1.1/1.0 web 框架,例如 Nodejs express, php WordPress, python Flask, nginx, java SpringBoot 等等, 还能利用 Lambda 省去了大部分的运维工作,同时实现自动容量调配和弹性伸缩。

参考资料

Lambda Web Adapter 开源文档:

https://github.com/awslabs/aws-lambda-web-adapter

Lambda 服务:

https://aws.amazon.com/cn/lambda/

SAM CLI:

https://docs.aws.amazon.com/zh_cn/serverless-application-model/latest/developerguide/serverless-sam-cli-install-mac.html

Amazon CLI:

https://docs.aws.amazon.com/zh_cn/cli/latest/userguide/cli-configure-files.html

如何开发参考:

https://github.com/awslabs/aws-lambda-web-adapter/blob/main/docs/development.md

本篇作者

50344fc3602cff82a5d30f32d67253c1.jpeg

谢佰臻

Amazon Web Services 公司解决方案架构师,负责基于云计算方案架构的咨询和设计,目前专注于 Serverless ,DevSecOps。

3dd9355a72c64d3d2938f69466d8fb2f.jpeg

王寒冰

亚马逊云科技解决方案架构师,负责基于亚马逊云计算方案的架构咨询和设计实现,具有丰富的解决客户实际问题的经验,专注于容器化,无服务器化的应用。

491bc0997198a134bdd8e98778fc6941.jpeg

7383c58405b1b4a37e9abf5f73746ad1.gif

367bff9063a6bf9b10183f3a2b9aefb7.gif

听说,点完下面4个按钮

就不会碰到bug了!

bdb774e8640b582793d201252c611e4a.gif

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值