요약정리
아래의 문답은 오라클 공식 홈페이지, 국내외 개발자들이 오라클에 직접 문의한 내용들을 토대로 작성되었습니다. 개인적인 의견이 아닌 오라클의 답변을 토대로 작성되었음을 알립니다. 이곳저곳에서 확실하게 팩트체크된 내용을 기반으로 정리한 사항입니다.
유료화 이슈 관련 사항은 다음의 오라클 홈페이지에 자세히 나와있습니다. [관련 링크]. 자극적인 기사 제목처럼 Java가 유료화 되는 것이 아니라 기존의 1회성 결제의 유료화 방식이 월별 결제 방식으로 변경되는 이슈와 커머셜한 기능들에 대한 유료화입니다.
: Java의 특정 기능이 유료화 되는 부분으로 웹을 개발하는 회사에서 사용하는 기능이 대상은 아닙니다. |
추후에 유료화 된 기능을 이용할 가능성은 없나요? |
: 네. 없습니다. 유료화 되는 커머셜(commercial) 기능에는 일반 Web 개발을 위한 기능은 없습니다. 다음의 JavaFX, Java Web Start 등등 입니다. 커머셜 기능의 자세한 내용은 https://www.oracle.com/technetwork/java/javase/terms/products/index.html 을 참고하시면 됩니다. 여기에 기술 기능을 알고 계시는 분들만 유료화 이슈를 생각하시면 됩니다. |
기존의 Oracle JDK를 사용해도 되나요? |
: 네. 사실 그냥 사용해도 위의 내용처럼 커머셜한 기능만 사용하지 않으면 과금되지 않습니다. 하지만 Oracle JDK에는 커머셜한 기능이 포함되어 있으므로 개발자도 모르게 사용할 가능성이 1%라도 존재하므로 OpenJDK 기반으로 개발 및 운영 환경을 셋팅합니다. OpenJDK기반으로 셋팅 시 커머셜한 기능이 빠진 상태이므로 유료화에 대하여 1%의 가능성도 존재하지 않습니다. |
Open JDK가 Oracle JDK보다 성능이 떨어지는건 아닌가요? |
제공되는 기능적 차이 외에는 Java6 이후부터는 Open JDK와 Oracle JDK간의 성능 차이는 없습니다. [관련 링크] |
어떠한 경우에 유료화에 포함되나요? |
: Oracle에서는 일반적인 목적의 컴퓨팅에 사용시에는 무료라고 밝히고 있습니다. [관련 링크] 일반적인 컴퓨팅이란 데스크탑, 노트북, 스마트폰, 태블릿 등에서의 사용이 이에 해당한다고 합니다. 일반적이지 않은 목적의 컴퓨팅(Non-General Purpose Computing)은 별도의 라이센스비를 지불해야하는 유료 과금 대상입니다. |
보안관련 이슈등 지원이 없다는데 기존 버전을 사용해도 되나요? |
: Java 뿐 아니라 모든 언어, 심지어 OS인 리눅스도 버전에 따라서 공식적인 지원은 언젠가는 중단됩니다. Java1.5의 지원은 중단되었지만 아직도 꽤 많은 점유율을 가지고 있습니다.(국내의 IE환경과 비교하시면 편합니다.) 유료화가 되어서 기존 버전들의 지원이 중단되는 것이 아니라 원래부터 언젠가는 지원이 중단되는 것이었습니다. 오라클에서 판매의 수단으로 보안이나 지원에 대한 부분을 강조하고 있을뿐입니다. 지원과 관련된 부분에 대한 의견이 많아 Open JDK 기반의 Zulu를 기반으로 개발환경을 셋팅하시면 됩니다. |
Zulu가 뭔가요? |
TCK 인증을 받은 JDK로 Open JDK 기반 빌드에 부가 기능을 넣은 JDK입니다. Oracle 유료화 이슈에 따른 가장 좋은 대안으로 평가 받고 있는 수단으로 무료로 이용이 가능합니다. [관련 링크] [관련 링크2] |
자바 유료화 관련 참고 자료
Oracle JDK와 OpenJDK의 차이점
- 제공되는 기능적 차이 외에 Java 6 시대에는 분명히 OpenJDK가 Oracle JDK보다 성능이나 안정성이 크게 떨어졌다. 하지만 오늘날에는 Oracle JDK만이 제공하는 일부 라이브러리를 제외하고는 차이가 없다. [관련 링크]
|
---|
Oracle JDK는 무료인가?
Oracle JDK는 BCL(Oracle Binary Code License) 라이센스로 위 기능을 일반적인 목적의 컴퓨팅(General Purpose Computing)에만 사용시 무료라고 밝히고 있다. [관련 링크] 일반적인 목적의 컴퓨팅이란 무엇일까? 오라클은 데스크탑, 노트북, 스마트폰, 태플릿 등에서의 사용이 이에 해당한다고 설명하고 있다. 즉, 개발환경에서는 사용에 있어 아무 문제가 없다. 일반적이지 않은 목적의 컴퓨팅(Non-General Purpose Computing)은 별도의 라이센스비를 지불해야 하는 유료 과금 대상이 된다. 오라클은 특정 기능 만을 위해 작동하는 시스템 및 솔루션에서의 사용이 이에 해당한다고 설명하고 있다. 이 부분의 애매한 표현 때문에 대부분의 상업 프로젝트를 진행하는 회사들은 OpenJDK를 사용한다.
|
---|
Oracle JDK의 유료 구독형 라이센스 전환
- Oracle JDK 바이너리에 적용되던 BCL 라이센스가 2018년 7월 부로
Java SE Subscription 라는 이름의 년 단위 유료 구독형 라이센스로 새롭게 개편되었다. - 새로운 라이센스는 서버 및 클라우드 인스턴스의 경우 프로세서 당 월 25달러를, 데스크탑의 경우 사용자 당 월 2.5달러를 요구한다. 대량구매 및 2년, 3년 장기 구독에 따른 할인이 제공된다.
- 구독한 라이센스 기간이 종료되면 사용자는 사용 권리를 잃어버린다. 라이센스를 갱신하거나 다른 무료 OpenJDK바이너리로 전환해야 한다. (GPL 라이센스 기반의 OpenJDK 소스 코드는 LTS 지원 없이 6개월마다 새로운 버전이 공개된다.)
- 새로운 라이센스는 2018년 9월 출시 예정인 Oracle JDK 11 바이너리부터 적용된다. 또한, 오직 라이센스 구독자 만이 LTS 업데이트 지원을 받을 수 있다. (다음 LTS 지원 버전의 출시는 3년 뒤로 Oracle JDK 17이 된다.)
- 기존 Oracle JDK 8 바이너리의 경우 2019년 1월 이후 업데이트부터 라이센스 구독을 요구한다.
- 새로운 라이센스에서도 비상업적인 용도에 한해서는 이전과 같은 무료 사용이 가능하다.
|
---|
OpenJDK는 운영 환경에 부적합한가?
- 결론부터 이야기하면 TCK 인증을 받은 OpenJDK 기반의 빌드 버전을 사용하면 운영 환경에 아무런 문제가 없다.
- Java SE 7부터 모든 JDK는 OpenJDK 레퍼런스 소스 코드를 기반으로 제작된다. (Jave SE 6 버전의 OpenJDK는 백포트 방식으로 구현되어 성능 저하 이슈가 존재한다.) OpenJDK는 자바 스펙을 명시한 JSR 336, JSR 337를 빠짐없이 완전히 구현한 구현체이다.
- OpenJDK의 운영 주체는 오라클이다. 오라클 또한 OpenJDK를 기반으로 자사의 부가적인 기능을 추가한 Oracle JDK를 제작하여 배포한다.
- 오라클이 아닌 서드파티 업체가 OpenJDK를 기반으로 공인된 JDK를 제작하여 배포하려면 오라클의 유료 라이센스인
OCTLA 에 가입해야 한다. 현재 전세계에 19개 업체가 가입되어 있다. [관련 링크] 이 업체들이 OpenJDK 기반의 자체 빌드를 배포하려면 오라클의 엄격한 TCK 인증을 통과해야 한다. 수만가지의 테스트를 단 하나라도 통과하지 못하면 인증되지 않는다. - OpenJDK를 멀티 플랫폼 바이너리로 빌드하여 배포하는 대표적인 업체로는
Azul Systems 가 있다. 개발 환경과 운영 환경 모두 Oracle JDK의 대안으로 좋은 평가를 받고 있다. [관련 링크]
|
---|
OpenJDK 구현체
OpenJDK의 명세는 JCP(오라클, IBM, SAP 등으로 구성)에 의해서 결정된다. OpenJDK는 결정된 스펙(Java SE 7: JSR 336, Java SE 8: JSR 337)을 구현한 레퍼런스 소스 코드이다. 많은 상업 JVM 벤더들이 이 OpenJDK 레퍼런스 소스 코드를 기반으로 각자의 JVM을 제작한다. 엄격한 테스트의 TCK 인증을 통과하면 OpenJDK를 완벽히 준수하는 구현체로 인정된다. Oracle JDK 또한 Java SE 7부터 이 OpenJDK를 기반으로 앞서 설명한 추가 요소를 담아 배포한다. [관련 링크]
- 트위터는 OpenJDK를 자사에 맞게 튜닝한 Twitter-JDK 위에서 자사의 서비스를 운영한다. [관련 링크]
Azul Systems (미국 소재의 Java Runtime 제작 전문 회사)는 Zulu 라는 OpenJDK 기반 빌드에 부가 기능을 추가한 Windows, Linux, Mac OS X 바이너리를 무료로 제공한다. 이 회사는 서버 부하에 최적화된 Zing 이라는 JVM을 판매한다. 엔터프라이즈 시장에서 Oracle JDK의 대안으로는 현재 독보적 위치에 있다. 테스트에서 Oracle JDK보다 성능이 좋았다는 사례도 있다. [관련 링크] 실제로 고성능을 요구하는 Cassandra 노드들은 Zing 기반으로 운영된다. [관련 링크]
|
---|