1P by neo 1일전 | favorite | 댓글 1개
  • Java를 위한 고성능 임베더블 Python 3 런타임
  • Java에서 직접 Python 패키지를 로드하고 사용할 수 있음
  • 최신 Python AI 및 데이터 과학 패키지와 호환 가능
  • Graal JIT 컴파일러를 통해 네이티브 코드 속도로 Python 실행 가능
  • Jython 사용자에게 업그레이드 경로 제공
  • Java에서 Python 스크립트를 사용하여 Java 클래스 및 프레임워크와 상호작용 가능
  • GraalVM Native Image를 사용하여 Python 애플리케이션을 단일 바이너리로 패키징 가능

GN⁺의 정리

  • GraalPy는 Java에서 Python을 고성능으로 실행할 수 있는 런타임을 제공함
  • Jython 사용자에게 현대적인 Python 기능을 사용할 수 있는 업그레이드 경로를 제공함
  • GraalVM의 폴리글랏 인터페이스를 통해 Python 데이터 과학 라이브러리를 Java 애플리케이션에 쉽게 통합할 수 있음
  • Python과 Java의 상호 운용성을 높여 개발자에게 유연성을 제공함
  • 비슷한 기능을 제공하는 프로젝트로는 Jython과 Py4J가 있음
Hacker News 의견
  • GraalPy와 JDK8을 비교한 벤치마크 결과를 공유함

    • JDK8이 GraalPython EE 22.3 Hotspot보다 약 2.4배 빠름
    • JDK8이 CPython 3.11보다 41배 빠름
    • GraalPython이 CPython보다 약 17배 빠르고, PyPy보다 약 2배 빠름
    • Graal Enterprise Edition (EE)이 Community Edition (CE)보다 약 1.31배 빠름
  • GraalVM을 사용해 큰 프로젝트를 실행하려 했으나 몇 가지 문제 발생

    • Maturin이 Graal 인터프리터를 지원하지 않아 Py03 패키지 사용 불가
    • uv가 실행되지 않으며, os 패키지에서 forkexecve가 누락됨
    • Graal이 인기 있는 라이브러리에 많은 패치를 적용해야 함
    • 큰 프로젝트에 Graal을 사용하는 것은 높은 위험성 때문에 어려움
  • GraalVM이 Java (또는 Scala) 함수를 브리지 없이 직접 호출할 수 있다면, Spark를 사용하는 프로그램에 유용할 것이라는 의견

  • Python의 흥미로운 점은 ML 툴체인, CUDA, Metal/MLX, pytorch, tensorflow, LLM 인코더/디코더 등과의 통합임

    • GraalVM이 이러한 코드들을 의미 있게 실행할 수 있는지 의문
  • Clojure에서 Java/Python 통합을 이미 구현한 사례가 있음

    • Chris Neurnberger와 libpython-clj 덕분에 가능
  • DuckDB는 현재 지원되지 않지만, Pandas와 matplotlib은 지원됨

    • DuckDB와 Polars가 지원된다면 많은 데이터 작업에 도움이 될 것이라는 의견
  • GraalPy가 Python 3.11을 타겟으로 한다는 것을 발견

    • GIL에 대한 언급은 없었음
    • Python 사용자라면 빠른 시작 링크를 클릭하지 말라는 경고
  • GraalPy의 사용 사례에 대한 의문 제기

    • 왜 GraalPy를 사용해야 하는지 이해하지 못하겠다는 의견
  • GraalPy가 GraalVM에서만 실행되어야 하는지, 다른 JVM 구현에서도 가능한지에 대한 질문