> Java > java지도 시간 > GraalVM 네이티브 이미지를 사용한 Lambda 함수 - 사용자 지정 런타임으로 Lambda 함수를 개발하고 배포하는 부분

GraalVM 네이티브 이미지를 사용한 Lambda 함수 - 사용자 지정 런타임으로 Lambda 함수를 개발하고 배포하는 부분

Mary-Kate Olsen
풀어 주다: 2024-10-21 16:16:30
원래의
954명이 탐색했습니다.

소개

시리즈 1부에서는 GraalVM, 특히 네이티브 이미지 기능을 소개했습니다. 또한 서버리스 애플리케이션에 대한 이점도 설명했습니다. 시리즈의 이 부분에서는 GraalVM 네이티브 이미지가 포함된 사용자 정의 런타임을 사용하여 AWS Lambda 함수를 개발하고 배포하는 방법을 설명합니다.

샘플 애플리케이션

설명을 위해 샘플 애플리케이션을 사용하겠습니다. 이 애플리케이션에서는 제품을 생성 및 검색하고 DynamoDB를 NoSQL 데이터베이스로 사용합니다. Java 21 Lambda 콜드 스타트 ​​측정 문서에 소개된 애플리케이션을 재사용하고 GraalVM 네이티브 이미지가 포함된 Lambda 사용자 정의 런타임으로 배포되도록 조정하겠습니다.

Lambda function with GraalVM Native Image - Part ow to develop and deploy Lambda function with custom runtime

일반 설정

GraalVM 네이티브 이미지를 구축하려면 다음을 수행해야 합니다.

  • 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 네이티브 이미지를 지원하도록 만들기

샘플 애플리케이션을 GraalVM 네이티브 이미지로 실행하려면 리플렉션별로 객체가 인스턴스화될 모든 클래스를 선언해야 합니다. 이러한 클래스는 컴파일 타임에 AOT 컴파일러에 의해 알려져야 했습니다. 이는 Reflect.json에서 발생합니다. 보시다시피 우리는 거기에 선언해야 합니다

  • GetProductByIdHandler 및 CreateProductHandler와 같은 모든 Lambda 함수
  • JSON 페이로드에서 다시 변환될 제품 및 제품과 같은 엔터티
  • GetProductByIdHandler 및 CreateProductHandler와 같은 Lambda 함수에서 이 이벤트 유형을 요청 이벤트로 선언했기 때문에 APIGatewayProxyRequestEvent 및 모든 내부 클래스
  • APIGateway 프록시 요청 및 응답 이벤트의 일부인 문자열과 그 반대로 타임스탬프를 변환하는 데 사용되는 org.joda.time.DateTime

네이티브 이미지의 클래스 초기화 문서에 설명된 초기화 중 로거 관련 오류를 방지하려면 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 사용자 정의 런타임

Lambda 함수를 사용자 정의 런타임으로 배포하려면 bootstrap 이름의 파일을 포함하는 .zip 확장자를 사용하여 모든 것을 파일로 패키징해야 합니다. 이 파일은 우리의 경우 GraalVM 네이티브 이미지일 수도 있고 다른 파일에 있는 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>

로그인 후 복사
결국 우리는 다음을 사용하여 Lambda 사용자 정의 런타임으로 배포할 수 있는 zip 파일로 패키지된 GraalVM 네이티브 이미지를 구축해야 합니다.


<dependency>
   <groupId>com.formkiq</groupId>
   <artifactId>lambda-runtime-graalvm</artifactId>
   <version>2.3.1</version>
</dependency>
로그인 후 복사
GraalVM 네이티브 이미지를 Lambda 사용자 지정 런타임으로 배포

AWS SAM 템플릿에서 우리는 Lambda 런타임을 사용자 지정 런타임의 최신 버전인

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿