티스토리 뷰

SW 개발/Java

Java, JVM 옵션 설정하기

지단로보트 2017. 8. 7. 13:32

JVM 실행 옵션 예

$ java -server -Xms8g -Xmx8g -XX:MaxMetaspaceSize=256m -XX:+CMSClassUnloadingEnabled -Dspring.profiles.active=prod -jar app.jar 
  • 힙 크기에 관한 어떤 설정도 하지 않을 경우 JVM은 물리 메모리의 1/6 크기를 최소 힙 크기(-Xms)에, 물리 메모리의 1/4 크기를 최대 힙 크기(-Xmx)에 할당한다. 물리 메모리가 32GB라고 가정하면 -Xms4g, -Xmx8g 정도를 할당하는 셈이다. [관련 링크]
  • JVM은 애플리케이션 시작시 -Xms로 설정한 값으로 힙 크기를 생성하고 요구량이 증가할 때마다 -Xmx로 설정한 값까지 점진적으로 힙 크기를 늘린다. 힙 크기를 늘리는 과정에서 애플리케이션이 일시적으로 멈추는 병목 현상(Stop the World Event)이 발생할 수 있다. 따라서 물리 메모리가 넉넉하다면 처음부터 -Xms 값을 -Xmx와 동일하게 설정하는 방법을 추천하기도 한다. [관련 링크 1] [관련 링크2]
  • 한편, 64-bit 환경에서 물리 메모리가 32GB를 훨씬 초과하는 시스템이라고 하더라도 -Xmx 옵션을 32GB 이하로 설정하는 것이 적절하다. 32GB를 초과하면 힙을 관리하는 방식이 비효율적인 방식으로 변경된다. [관련 링크 1] [관련 링크 2]
  • -XX:MaxMetaspaceSizePermanent Generation 영역을 의미한다. 과거 -XX:MaxPermSize 용어로 쓰이다가 Java 8에 와서 명칭이 바뀌었다. 값을 지정하지 않으면 기본 값으로 64MB가 사용되는데 일반적인 엔터프라이즈 용도라는 낮은 수치이다. 오라클에서는 256MB로 설정할 것을 권장한다.
  • -XX:MaxDirectMemorySizejava.nio 패키지의 최대 Direct Buffer 할당 크기를 의미한다. (이 영역은 네트워크 데이터 전송 및 오브젝트 직렬화에 사용된다.) 생략할 경우 일반적으로 —Xmx 옵션에 할당된 크기와 동일한 값이 설정된다. 이 크기가 부족할 경우 런타임에서 OutOfMemoryError: Direct buffer memory 오류가 발생한다. [관련 링크]

참고 글

댓글
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/04   »
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30
글 보관함