시리즈 1부에서는 GraalVM, 특히 네이티브 이미지 기능을 소개했습니다. 또한 서버리스 애플리케이션에 대한 이점도 설명했습니다. 시리즈의 이 부분에서는 GraalVM 네이티브 이미지가 포함된 사용자 정의 런타임을 사용하여 AWS Lambda 함수를 개발하고 배포하는 방법을 설명합니다.
설명을 위해 샘플 애플리케이션을 사용하겠습니다. 이 애플리케이션에서는 제품을 생성 및 검색하고 DynamoDB를 NoSQL 데이터베이스로 사용합니다. Java 21 Lambda 콜드 스타트 측정 문서에 소개된 애플리케이션을 재사용하고 GraalVM 네이티브 이미지가 포함된 Lambda 사용자 정의 런타임으로 배포되도록 조정하겠습니다.
GraalVM 네이티브 이미지를 구축하려면 다음을 수행해야 합니다.
curl -s "https://get.sdkman.io" | bash source "/home/ec2-user/.sdkman/bin/sdkman-init.sh"
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
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 네이티브 이미지로 실행하려면 리플렉션별로 객체가 인스턴스화될 모든 클래스를 선언해야 합니다. 이러한 클래스는 컴파일 타임에 AOT 컴파일러에 의해 알려져야 했습니다. 이는 Reflect.json에서 발생합니다. 보시다시피 우리는 거기에 선언해야 합니다
네이티브 이미지의 클래스 초기화 문서에 설명된 초기화 중 로거 관련 오류를 방지하려면 Native-image.properties에 GraalVM 네이티브 이미지 빌드 인수를 추가해야 합니다.
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를 사용하므로 네이티브-image.properties를 META-INF/native-image/org.slf4j/slf4j-simple 경로에 배치해야 합니다.
Lambda 함수를 사용자 정의 런타임으로 배포하려면 bootstrap 이름의 파일을 포함하는 .zip 확장자를 사용하여 모든 것을 파일로 패키징해야 합니다. 이 파일은 우리의 경우 GraalVM 네이티브 이미지일 수도 있고 다른 파일에 있는 GraalVM 네이티브 이미지를 호출하는 방법에 대한 지침을 포함할 수도 있습니다. 살펴보겠습니다.
pom.xml에 정의된 패키지 단계에서 GraalVM 네이티브 이미지를 자동으로 빌드합니다. 관련 부분은 다음 플러그인에 정의되어 있습니다.
sdk install java 22.0.1-graal (or use the newest GraalVM version)
org.graalvm.nativeimage 도구의 Native-image-maven-plugin을 사용하고 패키지 단계에서 기본 이미지를 실행합니다. 이 플러그인에는 Lambda 함수에 없는 기본 클래스의 정의가 필요합니다. 이것이 바로 우리가 Lambda 런타임 GraalVM을 사용하고 기본 클래스 com.formkiq.lambda.runtime.graalvm.LambdaRuntime을 정의하는 이유입니다. Lambda 런타임 GraalVM은 Java 프로그래밍 언어로 작성된 AWS Lambda를 GraalVM으로 쉽게 변환할 수 있게 해주는 Java 라이브러리입니다. 이전에 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 네이티브 이미지를 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
우리가 function으로 정의하는 finalName과 native-zip으로 id를 정의합니다. 또한 Native.xml 어셈블리도 포함합니다. 이 어셈블리는 파일 형식을 zip(전체 파일 이름은 ${finalName}-${id}.zip, 이 경우 function-native-zip.zip)으로 정의하고 이전에 빌드된 GraalVM 네이티브 이미지를 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>
<dependency> <groupId>com.formkiq</groupId> <artifactId>lambda-runtime-graalvm</artifactId> <version>2.3.1</version> </dependency>
provided.al2023으로 지정하고 이전에 빌드된 GraalVM 네이티브 이미지 function-native-zip에 대한 경로를 제공합니다. 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 네이티브 이미지가 포함된 사용자 지정 런타임을 사용하여 AWS Lambda 함수를 개발하고 배포하는 방법을 설명했습니다. 시리즈의 다음 부분에서는 Lambda 함수의 다양한 메모리 설정에 대한 시나리오에 대해 Lambda 함수의 콜드 시작 및 웜 시작 시간을 측정하겠습니다.
위 내용은 GraalVM 네이티브 이미지를 사용한 Lambda 함수 - 사용자 지정 런타임으로 Lambda 함수를 개발하고 배포하는 부분의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!