전략을 시작하기 전에 Java 애플리케이션의 맥락에서 시작 시간과 메모리 공간이 무엇을 의미하는지 이해해 보겠습니다.
시작 시간은 Java 애플리케이션이 시작된 후 요청을 처리할 준비가 되는 데 걸리는 시간을 나타냅니다. 빠른 배포와 가용성이 필수적인 애플리케이션에서는 시작 시간을 최소화하는 것이 중요합니다.
Java 애플리케이션의 메모리 사용량은 실행 중에 소비하는 메모리 양입니다. 메모리 공간이 크면 특히 클라우드 환경에서 비용이 증가하고 대기 시간이 길어질 수 있습니다.
여기에서는 Java 애플리케이션의 시작 시간을 줄이는 다양한 방법을 살펴보겠습니다.
클래스 데이터 공유(CDS)는 JVM이 여러 Java 프로세스에서 공통 클래스 메타데이터를 공유할 수 있도록 하여 클래스를 로드하는 데 걸리는 시간을 줄이는 기술입니다.
예:
java -Xshare:dump -XX:+UseAppCDS -XX:SharedClassListFile=classlist -XX:SharedArchiveFile=app-cds.jsa -cp myapp.jar
이 명령은 미리 로드된 클래스를 사용하여 애플리케이션을 더 빠르게 시작하는 데 사용할 수 있는 공유 아카이브를 생성합니다.
CDS를 활성화하면 애플리케이션의 복잡성에 따라 시작 시간을 약 15% 줄일 수 있습니다.
GraalVM을 사용하면 Java 코드를 기본 바이너리로 컴파일하여 JVM 워밍업을 방지하여 시작 시간을 크게 줄일 수 있습니다.
GraalVM은 여러 언어를 지원할 뿐만 아니라 Java 애플리케이션 최적화를 위한 강력한 기능을 제공하는 고급 다중 언어 가상 머신입니다. GraalVM의 뛰어난 기능 중 하나는 Java 애플리케이션을 기본 바이너리로 컴파일하는 기능입니다. 이 프로세스를 AOT(Ahead-of-Time) 컴파일이라고 하며, 특히 시작 시간 단축 측면에서 상당한 성능 이점을 제공합니다.
GraalVM의 네이티브 이미지 도구를 사용하여 Java 애플리케이션을 컴파일하면 전체 애플리케이션이 해당 종속성 및 JVM의 필수 부분과 함께 단일 네이티브 실행 파일로 컴파일됩니다. 이 실행 파일은 바이트코드를 해석하기 위해 JVM(Java Virtual Machine) 없이 운영 체제에서 직접 실행할 수 있습니다.
예:
java -Xshare:dump -XX:+UseAppCDS -XX:SharedClassListFile=classlist -XX:SharedArchiveFile=app-cds.jsa -cp myapp.jar
이 명령은 애플리케이션을 기본 실행 파일로 변환하여 거의 즉시 시작됩니다.
GraalVM 네이티브 이미지를 사용하면 시작 시간을 최대 90%까지 줄일 수 있지만, 모든 Java 기능을 지원하지 않을 수 있으므로 철저한 테스트가 필요합니다.
AOT 컴파일에는 애플리케이션이 실행되기 전에 Java 바이트코드를 기본 기계 코드로 미리 변환하는 작업이 포함됩니다. 이 프로세스는 컴파일된 기계 코드와 필요한 런타임 구성 요소를 포함하는 실행 가능한 바이너리를 생성합니다. 목표는 애플리케이션 시작 및 실행 중에 JIT 컴파일의 필요성을 제거하거나 최소화하는 것입니다.
AOT 컴파일 프로세스 중에 Java 컴파일러 또는 GraalVM의 네이티브 이미지와 같은 특수 도구는 Java 소스 코드에서 네이티브 실행 파일을 생성합니다. 그런 다음 이 네이티브 코드는 JVM이 즉시 JIT 컴파일을 수행할 필요를 우회하여 애플리케이션을 직접 실행하는 데 사용됩니다.
예:
native-image -jar myapp.jar
이 명령은 특정 메소드를 사전 컴파일하여 JIT 컴파일에 소요되는 시간을 줄입니다.
AOT는 특히 초기화 시퀀스가 복잡한 애플리케이션의 경우 시작 시간을 약 10%까지 줄일 수 있습니다.
클래스 경로의 클래스와 라이브러리 수를 줄이는 것도 시작 시간을 단축하는 데 도움이 될 수 있습니다.
예 : jlink와 같은 도구를 사용하여 사용자 정의 JRE를 만듭니다.
java -XX:+UnlockExperimentalVMOptions -XX:AOTLibrary=./myapp.so -cp myapp.jar
이 사용자 정의 JRE에는 애플리케이션에 필요한 모듈만 포함되어 오버헤드가 줄어듭니다.
이 최적화를 통해 불필요한 클래스가 로드되는 것을 제거하여 시작 시간을 5~10% 줄일 수 있습니다.
메모리 사용량 감소는 애플리케이션 확장에 매우 중요하며, 특히 사용량에 따라 리소스 요금이 청구되는 클라우드 환경에서는 더욱 그렇습니다.
G1 Garbage Collector는 일시 중지 시간을 최소화하도록 설계되었으며 라이브 개체를 압축하여 메모리 사용량을 줄일 수 있습니다.
예
jlink --module-path $JAVA_HOME/jmods --add-modules java.base,java.sql --output custom-jre
이 명령은 최적화된 힙 설정으로 G1 GC를 사용하도록 JVM을 구성합니다.
G1 GC는 라이브 데이터가 많은 애플리케이션에서 메모리 공간을 최대 30%까지 줄일 수 있습니다.
힙 크기, 스택 크기, 메타공간 등 JVM 메모리 설정을 조정하면 메모리 공간을 크게 줄일 수 있습니다.
예:
java -Xshare:dump -XX:+UseAppCDS -XX:SharedClassListFile=classlist -XX:SharedArchiveFile=app-cds.jsa -cp myapp.jar
이 명령은 힙 및 메타공간 설정을 미세 조정하여 메모리 소비를 줄입니다.
신중하게 메모리를 조정하면 메모리 사용량이 20~30% 감소할 수 있습니다.
JVM은 중복 문자열을 감지하고 하나의 복사본만 메모리에 저장하여 애플리케이션이 동일한 문자열을 많이 사용할 때 공간을 절약할 수 있습니다.
예:
native-image -jar myapp.jar
이 명령은 문자열 중복 제거를 활성화하여 중복 문자열이 많이 있을 때 메모리 사용량을 줄입니다.
문자열 중복 제거는 특히 텍스트가 많은 애플리케이션에서 메모리 사용량을 최대 10%까지 줄일 수 있습니다.
과도한 객체 생성은 메모리 사용량을 증가시킬 수 있습니다. 불필요한 할당을 최소화하려면 객체 풀이나 불변 객체를 사용하세요.
예:
java -XX:+UnlockExperimentalVMOptions -XX:AOTLibrary=./myapp.so -cp myapp.jar
이 싱글턴 패턴은 애플리케이션 수명 주기 동안 생성되는 객체 수를 줄입니다.
객체 생성을 줄이면 애플리케이션 구조에 따라 메모리 사용량을 10~20% 줄일 수 있습니다.
Java 애플리케이션의 시작 시간과 메모리 공간을 최적화하면 성능이 크게 향상되고 비용이 절감될 수 있습니다. CDS 활성화, GraalVM 사용, AOT 컴파일, 메모리 조정 등 논의된 전략을 구현하면 원하는 시작 시간 60% 감소와 메모리 사용량 50% 감소를 달성할 수 있습니다. 이러한 최적화는 클라우드 플랫폼과 같이 리소스가 제한된 환경에서 특히 효과적입니다.
모든 애플리케이션은 고유하므로 특정 환경에서 이러한 전략을 테스트하여 예상 결과를 제공하는지 확인하는 것이 중요합니다.
질문이 있거나 이러한 기술에 대해 추가 설명이 필요한 경우 아래에 댓글을 남겨주세요!
에서 자세한 게시물 읽기: Java 앱의 시작 시간과 메모리 공간을 최대 60% 줄이기 위한 전략
위 내용은 Java 앱의 시작 시간과 메모리 공간을 최대로 줄이는 전략의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!