Post

TIL(20241104) [Creator_hub 프로젝트 - 트러블 슈팅]


spring boot 3.X.X버전에서 Apache spark를 사용하기는 하늘의 별따기라는 것을 느끼고 있다.

일단 3.X.X버전이하로 간신히 연결했는데, 여기서 부터 알 수 있다.

나는 spark를 사용하려면 자바 17버전은 사용하지 못한다. 여기저기 블로그와 서치를 한 결과

1
Spring Boot 3.x에서 Apache Spark를 사용하는 데 어려움을 겪는 이유 중 하나는 호환성 문제입니다. Spring Boot 3.x는 Java 17 이상을 요구하지만, Apache Spark는 3.x 버전에서 Java 8 또는 11에 최적화되어 있습니다. 따라서, Spark 3.x 버전을 사용할 때 Java 17을 사용할 수 없는 경우가 많습니다. 

뚜둥.. ㅎㅎ

그래서 일단 spring boot를 2.7.18버전과 자바 11버전으로 낮추었다.

1
2
3
- spring Boot 2.x 버전은 Java 8과 11을 지원합니다. 이 버전대에서는 Java 11을 사용할 수 있습니다.
- Spring Boot 3.x 버전부터는 Java 17 이상을 요구합니다. 따라서, Spring Boot 3.x를 사용하려면 Java 17 이상을 사용해야 합니다.
요약하자면, Spring Boot 2.x는 Java 11과 호환되지만, Spring Boot 3.x는 Java 17 이상만 지원합니다.

spark는 최신버전을 사용해도 문제가 없었다. spark 3.5.3버전을 사용 중이다.

이제 왜 이렇게까지 되어야 하는지에 대해서 궁금증이 생겼다.

Apache spark view에서 javax패키지의 servlet을 사용하는데 spring boot 3버전은 javax-> jakarta로 변경되었다.

즉, spark를 사용하기 위해서는 jakarta.로 시작하는 패키지를 사용할 수 없다. 기존 코드와의 호환성 때문이다.

내가 spark를 사용하려고 했던 이유는 대용량 데이터를 빠르게 처리

1
2
3
4
5
WARNING: An illegal reflective access operation has occurred
WARNING: Illegal reflective access by org.apache.spark.unsafe.Platform (file:/C:/Users/guro13/.gradle/caches/modules-2/files-2.1/org.apache.spark/spark-unsafe_2.12/3.5.3/2b80fdeb3a47eea098c240db78d9aa8d153a1b2/spark-unsafe_2.12-3.5.3.jar) to constructor java.nio.DirectByteBuffer(long,int)
WARNING: Please consider reporting this to the maintainers of org.apache.spark.unsafe.Platform
WARNING: Use --illegal-access=warn to enable warnings of further illegal reflective access operations
WARNING: All illegal access operations will be denied in a future release

어플리케이션을 실행할 때 마다 이 로그가 뜨는데, 이 에러메세지는 다음과 같다. 불법 반사 접근은 Java에서 특정 클래스나 메서드에 접근할 때, 일반적으로 허용되지 않는 방법으로 접근하려고 할 때 발생하는 경고이다. 쉽게 말해, Java는 각 클래스와 메서드에 대한 접근 권한을 설정해 두는데, 그 규칙을 어기고 접근하려고 할 때 이 경고가 나타나는 것이다.

Java 9부터는 모듈 시스템이 도입되면서, 클래스의 접근 권한이 더 엄격해졌기에 이제는 특정 클래스에 접근하기 위해선 명시적으로 허락을 받아야 한다. 그런데 Spark는 내부적으로 DirectByteBuffer라는 특별한 메모리 버퍼를 사용해 성능을 높이는데, 이 클래스에 직접 접근해야 할 때가 있다고 한다. 그런데 Spark가 이 클래스의 접근 규칙을 무시하고 접근하려고 하다 보니, 경고가 발생하는 현상이다.

1
2
//Java의 모듈 시스템에서 특정 패키지에 대한 접근을 허용하는 명령어
--add-opens java.base/java.nio=ALL-UNNAMED

로 저 경고를 무시할 수 있지만.. 참 .. 착잡하다.. 방법을 찾고 싶지만 어디에서도 찾아보기가 힘들다..

This post is licensed under CC BY 4.0 by the author.