介绍
在本系列的第 1 部分中,我们介绍了 GraalVM,特别是它的 Native Image 功能。我们还解释了它对无服务器应用程序的好处。在本系列的这一部分中,我们将解释如何使用包含 GraalVM Native Image 的自定义运行时来开发和部署 AWS Lambda 函数。
申请样本
为了解释起见,我们将使用我们的示例应用程序。在此应用程序中,我们将创建和检索产品并使用 DynamoDB 作为 NoSQL 数据库。我们将重用测量 Java 21 Lambda 冷启动一文中介绍的应用程序,并将其调整为部署为包含 GraalVM 本机映像的 Lambda 自定义运行时。
常规设置
为了构建 GraalVM Native Image,我们需要执行以下操作:
- 设置 m5.large AWS Cloud9 EC2 实例。您当然可以使用自己的(本地)Linux 环境。
- 安装SDKMAN
curl -s "https://get.sdkman.io" | bash source "/home/ec2-user/.sdkman/bin/sdkman-init.sh"
- 安装最新的 GraalVM 版本。我在示例中使用了版本 22(但您可以使用最新的版本):
sdk install java 22.0.1-graal (or use the newest GraalVM version)
- 安装原生镜像
sudo yum install gcc glibc-devel zlib-devel sudo dnf install gcc glibc-devel zlib-devel libstdc++-static
- 安装能够使用已安装的 GraalVM 版本进行构建的 Maven。我们需要能够处理 Java 21 及更高版本源代码的 Maven 版本。例如 :
wget https://mirrors.estointernet.in/apache/maven/maven-3/3.8.5/binaries/apache-maven-3.8.5-bin.tar.gz tar -xvf apache-maven-3.8.5-bin.tar.gz sudo mv apache-maven-3.8.5 /opt/ M2_HOME='/opt/apache-maven-3.8.5' PATH="$M2_HOME/bin:$PATH" export PATH
如果此镜像不可用,请使用另一个适用于您的操作系统的镜像。
使示例应用程序具有 GraalVM Native Image 功能
为了让我们的示例应用程序作为 GraalVM Native Image 运行,我们需要声明每次反射将实例化对象的所有类。 AOT 编译器在编译时需要知道这些类。这发生在reflect.json 中。 正如我们所看到的,我们需要在那里声明
- 我们所有的 Lambda 函数,例如 GetProductByIdHandler 和 CreateProductHandler
- 实体,例如产品和将从 JSON 负载转换回来的产品
- APIGatewayProxyRequestEvent 及其所有内部类,因为我们在 GetProductByIdHandler 和 CreateProductHandler 等 Lambda 函数中将此事件类型声明为请求事件
- org.joda.time.DateTime 将用于将时间戳与字符串相互转换,这是 APIGateway 代理请求和响应事件的一部分
为了避免在本机映像中的类初始化一文中描述的初始化期间记录器出现错误,我们需要在 native-image.properties 中添加 GraalVM Native Image 构建参数。
curl -s "https://get.sdkman.io" | bash source "/home/ec2-user/.sdkman/bin/sdkman-init.sh"
native-image.properties 应放置在 META-INF/native-image/${MavenGroupIid}/${MavenArtifactId}
当我们在 pom.xml 中使用 slf4j-simple Logger 时,我们需要将 native-image.properties 放在路径 META-INF/native-image/org.slf4j/slf4j-simple 中。
Lambda 自定义运行时
为了将 Lambda 函数部署为自定义运行时,我们需要将所有内容打包到扩展名为 .zip 的文件中,其中包括名为 bootstrap 的文件。在我们的例子中,该文件可以是 GraalVM 本机映像,也可以包含如何调用放置在另一个文件中的 GraalVM 本机映像的说明。 让我们来探索一下。
构建 GraalVM 本机镜像
我们将在 pom.xml 中定义的包阶段自动构建 GraalVM Native 镜像。 相关部分在以下插件中定义:
sdk install java 22.0.1-graal (or use the newest GraalVM version)
我们使用org.graalvm.nativeimage工具中的native-image-maven-plugin,并在打包阶段执行native-image。该插件需要主类的定义,而 Lambda 函数没有。这就是我们使用 Lambda Runtime GraalVM 并定义其主类 com.formkiq.lambda.runtime.graalvm.LambdaRuntime 的原因。 Lambda 运行时 GraalVM 是一个 Java 库,可以轻松地将用 Java 编程语言编写的 AWS Lambda 转换为 GraalVM。我们之前在 pom.xml 中将其定义为依赖
sudo yum install gcc glibc-devel zlib-devel sudo dnf install gcc glibc-devel zlib-devel libstdc++-static
然后,我们给出本机映像名称 aws-pure-lambda-java21-graalvm-native-image 并包含一些 GraalVM 本机映像参数和之前定义的 reflect.json。
wget https://mirrors.estointernet.in/apache/maven/maven-3/3.8.5/binaries/apache-maven-3.8.5-bin.tar.gz tar -xvf apache-maven-3.8.5-bin.tar.gz sudo mv apache-maven-3.8.5 /opt/ M2_HOME='/opt/apache-maven-3.8.5' PATH="$M2_HOME/bin:$PATH" export PATH
为了将构建的 GraalVM Native Image 压缩为 Lambda Custom Runtime 所需的 function.zip,我们使用 maven-assemble 插件:
Args=--allow-incomplete-classpath \ --initialize-at-build-time=org.slf4j.simple.SimpleLogger,\ org.slf4j.LoggerFactory -- --trace-class-initialization=org.slf4j.simple.SimpleLogger,\ org.slf4j.LoggerFactory
我们定义的finalName为function,id为native-zip我们还包括native.xml程序集。该程序集将文件格式定义为 zip(完整的文件名将为 ${finalName}-${id}.zip,在我们的示例中为 function-native-zip.zip),添加之前构建的 GraalVM Native Image,其名称为 aws-pure-lambda-java21-graalvm-native-image 并添加已定义的引导程序,该引导程序基本上调用了 GraalVM 本机映像:
<plugin> <groupid>org.graalvm.nativeimage</groupid> <artifactid>native-image-maven-plugin</artifactid> <version>21.2.0</version> <executions> <execution> <goals> <goal>native-image</goal> </goals> <phase>package</phase> </execution> </executions> <configuration> <skip>false</skip> <mainclass>com.formkiq.lambda.runtime.graalvm.LambdaRuntime</mainclass> <imagename>aws-pure-lambda-java21-graalvm-native-image</imagename> <buildargs> --no-fallback --enable-http -H:ReflectionConfigurationFiles=../src/main/reflect.json </buildargs> </configuration> </plugin>
最后,我们必须构建打包为 zip 文件的 GraalVM 本机映像,该映像可以使用以下命令部署为 Lambda 自定义运行时:
<dependency> <groupid>com.formkiq</groupid> <artifactid>lambda-runtime-graalvm</artifactid> <version>2.3.1</version> </dependency>
将 GraalVM 本机映像部署为 Lambda 自定义运行时
在 AWS SAM 模板中,我们将 Lambda 运行时设置为 provided.al2023(这是自定义运行时的最新版本),并提供之前构建的 GraalVM Native Image function-native-zip 的路径。邮编。
<buildargs> --no-fallback --enable-http -H:ReflectionConfigurationFiles=../src/main/reflect.json </buildargs>
现在我们准备使用
部署我们的应用程序
curl -s "https://get.sdkman.io" | bash source "/home/ec2-user/.sdkman/bin/sdkman-init.sh"
结论
在本系列的这一部分中,我们解释了如何使用包含 GraalVM Native Image 的自定义运行时来开发和部署 AWS Lambda 函数。在本系列的下一部分中,我们将针对 Lambda 函数的不同内存设置,测量此类场景下 Lambda 函数的冷启动和热启动时间。
以上是带有 GraalVM Native Image 的 Lambda 函数 - 使用自定义运行时开发和部署 Lambda 函数的部分内容的详细内容。更多信息请关注PHP中文网其他相关文章!

本文分析了2025年的前四个JavaScript框架(React,Angular,Vue,Susve),比较了它们的性能,可伸缩性和未来前景。 尽管由于强大的社区和生态系统,所有这些都保持占主导地位,但它们的相对人口

本文介绍了SnakeyAml中的CVE-2022-1471漏洞,这是一个允许远程代码执行的关键缺陷。 它详细介绍了如何升级春季启动应用程序到Snakeyaml 1.33或更高版本的降低风险,强调了依赖性更新

本文讨论了使用咖啡因和Guava缓存在Java中实施多层缓存以提高应用程序性能。它涵盖设置,集成和绩效优势,以及配置和驱逐政策管理最佳PRA

Java的类上载涉及使用带有引导,扩展程序和应用程序类负载器的分层系统加载,链接和初始化类。父代授权模型确保首先加载核心类别,从而影响自定义类LOA

Node.js 20通过V8发动机改进可显着提高性能,特别是更快的垃圾收集和I/O。 新功能包括更好的WebSembly支持和精制的调试工具,提高开发人员的生产率和应用速度。

本文使用lambda表达式,流API,方法参考和可选探索将功能编程集成到Java中。 它突出显示了通过简洁性和不变性改善代码可读性和可维护性等好处

本文讨论了使用JPA进行对象相关映射,并具有高级功能,例如缓存和懒惰加载。它涵盖了设置,实体映射和优化性能的最佳实践,同时突出潜在的陷阱。[159个字符]


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver CS6
视觉化网页开发工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境