Development Artist

[Issue, Elasticsearch] Unrecognized VM option 'UseConcMarkSweepGC’. Error: Could 본문

TroubleShooting/Etc

[Issue, Elasticsearch] Unrecognized VM option 'UseConcMarkSweepGC’. Error: Could

JMcunst 2023. 11. 21. 13:36
728x90
반응형

이슈

엘라스틱서치 실습 중 "./bin/elasticsearch" 명령어 실행 시 아래와 같은 이슈 발생.

Unrecognized VM option 'UseConcMarkSweepGC’. Error: Could not create the Java Virtual Machine. Error: A fatal exception has occurred. Program will exit.

- 엘라스틱서치 클러스터가 UseConcMarkSweepGC 옵션을 사용하려고 하지만, 만드려는 Java 가상 머신 옵션에서는 제공하지 않는 옵션이기 때문에 엘라스틱서치 클러스터를 만들 수 없다고 한다.

해결

일단 몇 가지 접근 방법이 있을 것 같다.
UseConcMarkSweepGC 옵션은 config/jvm.options 파일에 기본적으로 정의되어 있다.
1. config/jvm.options 에서 해당 라인 삭제
  > 나는 엘라스틱서치 클러스터에서 해당 옵션 안쓰겠다!
2. Java 버전 변경
  > UseConcMarkSweepGC 옵션을 지원하는 JVM을 만들 수 있는 Java 버전을 사용하겠다!
 
나는 1을 채택한다.

왜?

- UseConcMarkSweepGC는 이전 버전의 HotSpot JVM에서 사용할 수 있었던 Garbage Collection 알고리즘 중 하나.
- 이 알고리즘은 Java 9에서 deprecated되었고, Java 14에서는 완전히 제거.
- Java 버전에 따라 사용 가능한 GC 알고리즘이 다를 수 있지만, 이제는 UseConcMarkSweepGC를 사용할 수 있는 Java 버전은 없다.
- 현재는 G1(Garbage First) GC 등이 주로 사용되며, 이 GC가 더욱 효율적이고 성능이 우수.
- 따라서, 현재의 Java 버전을 사용할 때는 UseConcMarkSweepGC를 기대하거나 사용하는 것은 권장되지 않는다.

논외

UseConcMarkSweepGC란?

GC는 다들 아시다시피, 가비지 컬랙션이다.
GC의 종류에는 몇 가지가 있는데, 그중 하나로 Concurrent Mark Sweep(CMS)이 있다.
따라서, 해당 옵션은 GC타입으로 Concurrent Mark Sweep (CMS) 을 사용하겠다는 옵션이다. 
자세한 사항은 GC 타입으로 구글링 해서 알아보길 바란다.

엘라스틱서치

Elasticsearch 7.0 버전 부터는 기본 배포판에 open-jdk 가 포함되어 있어 따로 Java를 설치 해 주지 않아도 됩니다. 대신 운영체제에 맞게 배포판을 받아야 합니다.

Sdkman

- Java 버전을 관리해주는 툴인데, 쉽게 Java 버전을 바꿀 수 있다.
-`echo $JAVA_HOME`을 해보면 `/Users/user/.sdkman/candidates/java/current` 잡혀있다. 
-`sdk list java` 명령어를 쳐보면, 아래와 같이 다양한 Java 버전이 보이고 Use로 현재 사용하고 있는 Java를 나타낸다. installed 되어 있다면, `sdk use java [Identifier]` 명령어로 쉽게 바꿀 수 있다.
- Java 버전 설치를 위해서는 `sdk install java [Identifier]` 명령어로 설치해주면 된다.

 

728x90
반응형
Comments