Java is Still Free 2.0.3
This doc is deprecated, please see the latest version:
This is a repeat of (version 2.0.3) of the Google Doc put together by the Java Champions community of independent Java leaders and experts.
- Older version 1.0.0 — 17th of Sept 2018 — If you’re curious where we were ~6 months ago.
- Portuguese translation by @leomrlima — TBD
- Spanish translation by @aalmiray et al — TBD
With the changes to Oracle JDK distribution and support, there has been considerable uncertainty over the rights to use Oracle JDK vs Oracle OpenJDK builds vs OpenJDK builds from other providers. There are various ways to get free updates (including security), and (new and existing) paid support models available from various vendors to consider. This document has a Shorter Version and a much Longer Version section with all of the detail.
Shorter Version
You can still get the Oracle OpenJDK builds and OpenJDK by other providers for free under an open source license, and the Oracle JDK remains free in some circumstances. See the callout and the rest of the section for the nuances on this.
Java SE / OpenJDK / Oracle OpenJDK Builds / Oracle JDK
The OpenJDK community creates and maintains the (GPLv2+CE) open-source Reference Implementation (RI) of the Java SE Specification as governed by the Java Community Process (JCP) and defined through an umbrella Java Specification Request (JSR) for each feature release.
There are implementations (mostly OpenJDK based) of Java SE from various providers such as AdoptOpenJDK, Amazon, Azul, BellSoft, Eclipse, IBM, jClarity, Red Hat, Oracle, SAP, and others.
Oracle JDK 8 is going through the “End of Public Updates” process, which means the April 2019 update will restrict commercial use. However, since Java SE 9, Oracle is also providing Oracle OpenJDK builds which are free for commercial use (but only updated for 6 months). There are also free OpenJDK builds which will be updated (including security patches) from other providers like AdoptOpenJDK, Amazon, Azul, BellSoft, IBM, jClarity, Red Hat, the Linux distros et al.
Going forward there are several options to get a JDK. We focus on Java SE 8 and Java SE 11 which is the first Long Term Support (LTS) release under the new release cadence.
Staying with Java SE 8
Some people want to continue using Java SE 8 for various reasons.
- Starting with the April 2019 update, Oracle JDK 8 will have commercial use restrictions. Through at least December 2020 the Oracle JDK will remain free for personal desktop use, development, testing, prototyping, demonstrating and for use with certain types of applications. After those dates, users can either go onto a paid support plan or use a Java SE 8 / OpenJDK 8 binary from another provider.
- You can also continue to use previous releases of Oracle JDK 8 downloaded under old licenses without updates at your own risk.
- If you are not using Oracle JDK 8, then your current Java SE 8 / OpenJDK 8 provider will provide updates and/or paid support plans to choose from.
I WANT $FREE AND FREE (AS IN USE) JAVA SE 8, WHAT DO I CHOOSE?
If you want updates (including security) of Java SE 8, use an OpenJDK binary distribution from an OpenJDK provider, i.e. Linux distros, AdoptOpenJDK, Amazon, Azul, BellSoft, IBM, jClarity, Red Hat, SAP, and others.
Getting Java SE 11 (LTS)
You have several options to choose from. Please read them carefully, especially as how Oracle JDK is managing releases and updates is changing from Java SE 11 onwards.
- Starting with Java SE 11, Oracle provides their (OpenJDK based) JDK via:
- Oracle OpenJDK builds — Under the existing GPLv2+CE license, and
- Oracle JDK — Under a paid commercial license (but free for individual use, development, testing, prototyping and demonstrating and with certain types of applications), for those who do not wish to use the GPLv2+CE, or who are using an Oracle JDK with an Oracle product or service.
NOTE: Oracle provides two quarterly updates for its Oracle OpenJDK builds and then transition users to the next version, every six months (this includes LTS).
- You can also get Java SE / OpenJDK binary distributions from a variety of other providers including Linux distros, AdoptOpenJDK, Azul, Amazon, BellSoft, IBM, jClarity, Oracle, Red Hat, SAP, and others. This gives you free updates (including security) for a length of time depending on whether it’s an LTS version or not.
I WANT $FREE AND FREE (AS IN USE) JAVA SE 11+, WHAT DO I CHOOSE?
Use the Oracle OpenJDK build under the Open Source (GPLv2+CE) license and follow the new six-month release cadence OR
Use an OpenJDK binary distribution from an alternative OpenJDK provider, i.e. Linux distros, AdoptOpenJDK, Amazon, Azul, BellSoft, IBM, jClarity, Red Hat, SAP, and others.
Paid Support
Oracle plans to provide full paid support for Oracle JDK 8 until at least 2025 and Oracle JDK 11 until at least 2026 (details). There is a wide range of paid support options for Java SE / OpenJDK 8 and 11 binaries from Azul, BellSoft, IBM, jClarity, Red Hat, and others.
The Longer Version
This section deliberately has a lot of detail as there are nuances that need to be clearly explained. Please do yourself and your colleagues a favor by setting aside some proper time to read this in full. You’ll thank yourself for it, seriously.
We’d also like to thank Simon Ritter, Stephen Colebourne, Hendrik Ebbers, Donald Smith, Jonas Konrad and many others for their earlier posts and permission to reuse their material. Appendix I — Signatories, Thanks and References gives a full list of accreditation and folks who are signatories to this document.
Feedback is welcome! Use this link where you can make suggested edits and comments.
Change Log
This document will be updated over time as new information comes to light or if there is a verified correction to some factual data. Please check back here for updates and/or follow our @Java_Champions Twitter handle.
Version — Date — Comments
1.0.0 — 17 Sept 2018 1000 UTC — Initial Public Release
1.0.1 — 29 Nov 2018 1951 UTC — Grammarly fixes
2.0.0 — 01 Mar 2019 2127 UTC — Updates to reflect the current OpenJDK / Java ecosystem
2.0.1–06 Mar 2019 0955 UTC — Minor updates for Liberica support
2.0.2- 09 Mar 2019 1439 UTC — Minor updates to Red Hat OpenJDK
Dissemination
The following sheet is tracking known dissemination of this document. Please update if you share this doc!
Introduction
With the recent changes to Oracle JDK distribution and support, there has been considerable uncertainty over the future of Java, over its lifecycle, and over vendor-provided support. This document summarizes the changes Oracle has made, and the options available for users of Java SE.
WHAT DO WE MEAN BY FREE?
In a nutshell, the word “free” has two distinct meanings in software:
“Free as in beer” refers to the cost (i.e. money) of the software (aka $free).
“Free as in speech” refers to what you are allowed to do with the software.
As explained in the Shorter Version, you can still get Java SE binaries “free as in beer” from Oracle and other Java SE / OpenJDK providers (but check the update policies).
Although there are proprietary and/or restricted usage implementations of Java SE out there (Azul Zing, Oracle JDK etc), for the vast majority of users there is always the option of using an OpenJDK binary, which is “free as in speech” as it is GPLv2+CE licensed.
These changes have happened within a short time frame creating a perfect storm of uncertainty as day to day developers, who don’t follow the industry news closely, get caught up. This leads to factually incorrect posts like:
Which are luckily counterbalanced by more accurate posts such as:
- Donald Smith (Senior Director, Java Platform Product Management — Oracle) — Update and FAQ on the Java SE Release Cadence
- Simon Ritter (Deputy CTO — Azul) — Eliminating Java Update Confusion
- Stephen Colebourne (Joda-Time author) — Java is still available at Zero Cost and Java Options
- Hendrik Ebbers (Co-founder Karakun) — Do I need to pay for Java now?
This article will cover the main areas of concern and what’s being done about those concerns by the ecosystem. By the end of this post, you should be reassured that Java SE is still being well looked after and that it has a future stronger than ever!
The New Six Month Release Cadence and LTS
Java SE now has a feature release every six months, using a new versioning scheme which was previously announced in 2017. Thanks to improvements in JCP processes, OpenJDK committers can now introduce spec changing features (such as var in Java SE 10) on the six-month cadence.
WHAT DOES LTS MEAN WITH REGARDS TO JAVA / OPENJDK?
Long Term Support (LTS) in OpenJDK is really just an understanding between the various contributors (led by Oracle and Red Hat) that the code line for Java SE 11 / 17 / 23 etc will be maintained for a longer period of time than six months.
Oracle will lead the first six months of an OpenJDK LTS code line, providing updates and producing Oracle OpenJDK builds, but will then afterward only provide updates for Oracle JDK, under a paid support plan.
However, Oracle will work with other OpenJDK vendors to hand over the OpenJDK LTS code line and allow them to continue working on it together to provide updates. Each vendor then has the choice of providing updates and/or paid support for the binaries they produce. This hand over has occurred for both Java SE 8 and Java SE 11 with Red Hat taking over those update projects.
NOTE: This does mean that in theory, Oracle’s JDK could differ from the OpenJDK based binaries produced by other providers (this has always been the case). However, Red Hat and other project leaders have led the efforts to keep them in sync.
Understanding the new versioning scheme (including what LTS means) and how new features are introduced impacts how each version is maintained. By maintenance, we mean the provision of update releases with security patches and important bug fixes.
UPDATES vs SUPPORT
Updates refer to the code patches (including security) that have gone into OpenJDK and Oracle JDK. These have typically gone in for free until vendors decide that there’s an End of Public Updates process.
Support means a commitment to fix bugs and it requires staff to answer users’ problems, and that costs money. To be clear there has never been free support for Oracle JDK or OpenJDK.
Up to and including OpenJDK 8 / Oracle JDK 8, updates were provided by Oracle and other OpenJDK committers within a “feature release”. Feature releases, such as 8u91, 8u111 and 8u131 (on a six-month cadence) were superseded by each subsequent feature release. For example, once 8u111 was released, you would not get updates on 8u91.
Starting with OpenJDK 9 / Oracle JDK 9, the new six-monthly release cycle came into effect and updates now occur between “feature releases”, i.e. Similar to 8u91 -> 8u111, once 12 is released, you will not get updates to 11 by Oracle (However, other OpenJDK committers, lead by Red Hat, will provide these).
Oracle Updates Plan
Until Java 8, Oracle provided updates for the Oracle JDK for a 3+ year lifecycle, and usage was permitted in personal as well as commercial settings. The updates provided no support, and support required the purchase of explicit licenses from Oracle. Paid support also entailed longer update cycles.
Starting with Java 9, Oracle has moved to a faster cadence for Oracle JDK and also started producing Oracle OpenJDK builds. Updates will generally be provided for 6 months before they are stopped upon release of the next version. If updates/support are required for a longer duration, or for production use, then it must be purchased from Oracle (i.e. You must be on Oracle JDK). Periodically, releases will be marked “LTS”. These releases will be supported by Oracle through their standard support licenses for an extended period. As of right now, the Oracle update plan for Oracle OpenJDK builds, with updates, is as follows:
The idea here is simple. As has been the model of Java SE going way back to the Sun era, Oracle focuses on new innovations and moving Java SE forward. Organizations who wish to remain on legacy versions can do so via commercial support offerings. Of course, for some Java SE users and development shops, such rapid upgrade is not feasible.
OpenJDK Updates Plan
The OpenJDK community works on a free, open-source implementation of the Java SE standard. Oracle contributes heavily to the project, and it is the basis for both Oracle OpenJDK builds and Oracle JDK. OpenJDK 11+ is interchangeable with Oracle JDK for applications that adhere to the Java SE standard. Oracle will continue to contribute to OpenJDK while they provide updates for the corresponding Oracle OpenJDK build version. Once that version is superseded, Oracle will cease contributing to that version and start updating the next one.
Oracle has been highly receptive to the idea of community maintenance (for OpenJDK 6 and 7) and will continue to support handover of OpenJDK to the community to a qualified volunteering entity once they have moved on to working on the next version. Red Hat stepped in to globally lead (and provide regular updates to) OpenJDK 6 and OpenJDK 7 projects after Oracle ended updates for them. After Red Hat stopped updating OpenJDK 6, Azul Systems stepped in to lead the project and they continue to provide updates to this day.
Red Hat is now leading OpenJDK 8 and OpenJDK 11. It is important to note that while Red Hat leads the OpenJDK 7, 8 and 11 projects, they are not the sole contributors! Other vendors provide patches and fixes as well. With OpenJDK 8, there will be more contribution than ever before from non-Red Hat companies, such as Amazon, Azul, BellSoft, IBM, jClarity, Google, SAP, and many others.
For consistency, the OpenJDK update cycle will be extended for the same versions that are deemed LTS for Oracle JDK. As of right now, OpenJDK support cycle is as follows:
NOTE: These times are subject to change and different providers all have slightly different timeline commitments. Therefore we use the term “At Least”.
Java SE / OpenJDK Providers
There are now a large number of Java SE / OpenJDK providers who provide either updates and/or paid support options. The following sections provide a lot of detail.
UPDATES vs SUPPORT
Updates refer to the code patches (including security) that have gone into OpenJDK and Oracle JDK. These have typically gone in for free until vendors decide that there’s an End of Public Updates.
Support means a commitment to fix bugs and it requires staff to answer users’ problems, and that costs money. To be clear there has never been free support for Oracle JDK or OpenJDK.
Why Would I Choose Commercial Support?
If you need a fix in a timely manner, someone to respond to your user requests, or if you want the reassurance that the binary you use is being backed by a vendor, then Azul, BellSoft, IBM, jClarity, Red Hat, Oracle et al. all offer choices.
A PHILOSOPHICAL POINT ON PAYING FOR OPEN SOURCE SOFTWARE
The industry at large has settled firmly on Open Source Software as the way forward. Because of its “Free as in speech” nature, OSS licenses allow folks to modify and adapt other people’s software without fear of punitive action.
Many folks also enjoy the “Free as in beer” nature of much OSS software, but this comes at a great cost to the authors! Software developers, like anyone else, need to put a roof over their heads and food on their table. Vendors like Oracle pour vast amounts of money into Java SE (think 10s of $ Millions per year at the very least) and they do need to somehow pay for that cost.
So although you’re certainly not obliged to go with a paid support option with one of the vendors, sometimes it’s worth thinking about how you, the end users, can support the Java SE ecosystem to ensure it has a long lasting future!
Provider Summary
Build yourself from Source
Build from Source [OpenJDK, no commercial support, need to self-build]:
- Mercurial: http://hg.openjdk.java.net/
- Tarballs (7+): https://openjdk-sources.osci.io/
- AdoptOpenJDK: https://www.github.com/AdoptOpenJDK/openjdk-build
Binary Distribution Summary
- All Major = Linux x86, Mac OS X, Windows x64
- Minor = various other platforms
Free Binary Distributions
Free Builds for Linux, Windows, Mac, etc. [OpenJDK, no commercial support]:
- AdoptOpenJDK (commercial support also available by IBM and jClarity)
- Amazon Corretto
- Azul Zulu (commercial support also available)
- BellSoft Liberica JDK (commercial support also available)
- Linux Distros
- Oracle OpenJDK build
- SapMachine
Commercially Supported Distributions
Commercially supported:
AdoptOpenJDK
- See IBM and jClarity below
Amazon Corretto [OpenJDK base]:
Azul Systems [OpenJDK base]:
BellSoft [OpenJDK base]:
IBM [OpenJDK base + OpenJDK with Eclipse OpenJ9 VM]:
jClarity [OpenJDK base]:
Oracle JDK [OpenJDK base]:
Red Hat [OpenJDK base]:
Linux Distros
The various Linux distros will continue to provide OpenJDK for their respective distributions including but not limited to Debian, Ubuntu, CentOS, Fedora, Mint, Alpine et al.
Support Options
- Linux Distros do not typically offer paid support, the exception being Red Hat for OpenJDK on RHEL.
Please visit your distro homepage for more information.
AdoptOpenJDK
AdoptOpenJDK is backed by Amazon, Azul, GoDaddy, IBM, jClarity, Pivotal, Red Hat and many more. It provides OpenJDK binary distributions (Hotspot and Eclipse OpenJ9 VMs) for a very wide range of platforms (Linux, Mac, Windows 32/64, Arm 32/64, z/OS, Solaris, AIX, PPC, s390 and more).
Support Options
- AdoptOpenJDK offers community support and provides well-tested binaries from OpenJDK and Eclipse OpenJ9 upstream projects.
- jClarity offers commercial support for OpenJDK (with Hotspot VM) binaries built at AdoptOpenJDK.
- IBM offers commercial support for OpenJDK (with HotSpot or Eclipse OpenJ9 VM) binaries built at AdoptOpenJDK.
Important Links
- AdoptOpenJDK home page
- AdoptOpenJDK Support Options
Amazon Corretto
Amazon Corretto is a no-cost, multiplatform, production-ready distribution of the OpenJDK. Corretto comes with long-term support that will include performance enhancements and security fixes. Amazon runs Corretto internally on thousands of production services and Corretto is certified as compatible with the Java SE standard. With Corretto, you can develop and run Java applications on popular operating systems, including Linux, Windows, and macOS.
Support Options
Amazon offers long-term support for Corretto on AWS and includes performance enhancements and security updates for Corretto 8 until at least June 2023 at no cost. Updates are planned to be released at least quarterly. Corretto 11, corresponding to OpenJDK 11 is currently in preview and will be generally available during the first half of 2019. Amazon will provide LTS for Corretto 11 with quarterly updates until at least August 2024.
Important Links
Azul
Azul provides OpenJDK binaries (Zulu) as well as a specialized Java platform (Zing).
Support Options
Azul offers an option for all companies that do not want to skip all Java SE versions between LTS releases but cannot switch to the newest version every 6 months. Next, to the support for all LTS releases, where Azul provides 1 more year of support than Oracle, Azul offers support for so-called Medium Term Support (MTS) releases for their Zulu JDK. Here you can buy commercial support for every second Java SE version regardless of if it is LTS or not. The support duration of these versions is different. Azul tries to provide a good time range to prepare migration to the next version and defines 3 different durations for support of Java SE versions.
Unlike Oracle, the commercial support of Zulu is not defined per CPU but based on the number of systems. A system is defined as a physical or virtual server. The only difference between standard and premium is the availability of support. By buying premium support you can call Azul 24x7.
Important Links
BellSoft
Liberica JDK is a supported OpenJDK based binary distribution for desktop, server or embedded use. Supported platforms: Linux x86 32 & 64 bit, Windows x86 32 & 64 bits, MacOS X, Linux ARM 32 & 64 bit, Solaris SPARC and x86. Additional platforms are available by request.
Support Options
Liberica JDK has commercial support for LTS versions. The support pricing is calculated based on the number of desktops, physical or virtual servers or embedded platforms. Please contact sales@bell-sw.com to get a quote.
Important Links
IBM
IBM provides native JDK bundles for AIX, Linux (on x86, Power, zSystems), z/OS and IBM i. IBM offers the IBM SDK for Java SE versions for use with IBM products or platforms and for developer use from developerWorks. IBM also supports OpenJDK LTS binaries built and tested at AdoptOpenJDK.
Support Options
For Java SE 7 and 8, IBM still provides security updates and bugfixes. The IBM support lifecycle will continue to be updated. Based on the new Java SE release schedule IBM has announced that the LTS releases will be available as OpenJDK with OpenJ9 binaries from AdoptOpenJDK.
Important Links
jClarity
The jClarity team consists of a number of well known Sun/Oracle Java Champions, Java User Group Leaders etc. jClarity co-founded AdoptOpenJDK and they currently lead the build team and hold the Chairperson and Director positions on the Technical Steering Committee. As well as commercial support for AdoptOpenJDK, users can also utilise their specialised performance analytics tools to ensure that migrations are smooth.
Support Options
jClarity supports the AdoptOpenJDK OpenJDK binary distributions (Hotspot) for a very wide range of platforms (Linux, Mac, Windows 32/64, Arm 32/64, Solaris, AIX, PPC, s390 and more). See jClarity’s AdoptOpenJDK Support for details.
Important Links
Oracle
Oracle now produces two JDK binaries: Oracle JDK and an Oracle OpenJDK release.
Support Options
In June 2018, Oracle replaced its legacy “Java SE Advanced” perpetual license support product with a Subscription based offering that includes license and support. One of them targets Java SE on the desktop and the other one Java SE on the server, cloud, and Java SE in general. If you do not use Java SE on the desktop the “Java SE Subscription” will be the right support model for you. If you use Java SE on the desktop for client applications the “Java SE Desktop Subscription” product is available. If your software uses a Java SE server and Java SE based clients you can subscribe to both offerings.
Commercial support for Java SE applications on the desktop might become quite important for some companies since Oracle will drop several important desktop features from the JDK starting with Java SE version 11. If you are using Java SE on the desktop please read:
- JavaFX Separate Module
- JavaFX Separate Module Part II
- JavaFX Separate Module Is Now Available
- Java client roadmap that was announced by Oracle in 2018.
Important Links
Red Hat
Red Hat produces OpenJDK binaries for various platforms that Red Hat Enterprise Linux runs on. Red Hat also provides its OpenJDK source RPMs for CentOS. Usually after 24h to 72h, the CentOS team has built binaries from it and has made these available for the CentOS distribution.
Support Options
Red Hat won’t provide Java SE 9 and 10 releases. The next distribution that Red Hat plans to release is OpenJDK 11 for Red Hat Enterprise Linux 7. Currently, Java SE 8 is the supported release for Red Hat Enterprise Linux and the company will support it until 2023.
Important Links
- General Support information from Red Hat
- Unsupported community built binaries Linux/Windows from Red Hat upstream (ojdkbuild)
Java Desktop / Java Web Start / JavaFX
There are a number of changes with Desktop Java SE starting with Oracle JDK 11 that you need to be aware of.
JavaFX / OpenJFX
Starting with Java SE 11, neither the OpenJDK builds or the Oracle JDK binaries include the JavaFX libraries. The JavaFX components will now be delivered as a separate SDK, or as artifacts that can be used via build tools (e.g. Apache Maven, Gradle et al.). As a positive consequence of this decoupling, JavaFX development can now have its own roadmap.
JavaFX is still being developed in OpenJFX, which is a project under the OpenJDK community umbrella. Oracle, other companies, and individuals in the wider community are actively developing JavaFX. An automatically synced GitHub mirror is created as well, lowering the barrier for developers to contribute code and issues to JavaFX.
At the moment builds for OpenJFX are only provided by Gluon but Azul, AdoptOpenJDK, and others also will bundle OpenJFX. As all the OpenJFX source code is 100% open, others can create or distribute binaries as well. At OpenJFX, a similar approach as the one in OpenJDK is followed, where after releasing JavaFX 11, the focus is on JavaFX 12 and so on.
Gluon provides a Support Plan for companies who want Long Term Support for JavaFX 11.
Java Packager
The javapackager, which allows bundling applications and its dependencies with (a subset of) the JVM is no longer part of OpenJFX and is removed from Oracle’s JDK and Oracle OpenJDK builds starting with Java 11. A JEP has been submitted for adding a Java Packaging Tool to OpenJDK. While the new Java Packaging Tool will not be ready for the Java 11 release, Gluon is working on a tool allowing Java 11 applications to be packaged into native images.
Java WebStart
If you are using Java Web Start technology to distribute desktop clients you should take care about the current situation since Oracle has removed Web Start from Java.
- IcedTea-Web is an alternative you can use
- AdoptOpenJDK will be supporting OpenJDK binaries with IcedTea-Web
- IBM will be supporting AdoptOpenJDK builds of OpenJDK with IcedTea-Web
- Builds from Red Hat include a simplified IcedTea-Web installer (ojdkbuild)
- Karakun is working on an OSS replacement for Web Start as well
FAQ
Q. Differences between OpenJDK vs Oracle OpenJDK builds vs Oracle JDK?
We’ll just talk about Java 11+ LTS releases here. Oracle JDK and Oracle OpenJDK build are identical, but are licensed in different ways (commercial and GPLv2+CE respectively).
Oracle JDK / Oracle OpenJDK builds and OpenJDK builds from other providers will be built from the same source for the first six months of updates and should be interchangeable for that period. After six months Oracle JDK / Oracle OpenJDK builds will be built from Oracle’s own fork. Other OpenJDK providers will continue to create binaries from the OpenJDK updates project. Oracle JDK / Oracle OpenJDK and OpenJDK build from the other providers may, therefore, differ in small ways. Binaries from various parties may, of course, vary over time.
Q. Differences between OpenJDK from (non-Oracle) provider A vs provider B?
We’ll just talk about LTS releases here. As has been the case with the Java SE 6 and Java SE 7 updates projects, various providers work together upstream in the OpenJDK community, which provides the common repositories, mailing lists, and other infra to share the work. This means the difference between OpenJDK-based binaries are mostly non-core features, like extended monitoring and diagnostic support. Although there may be small differences in the final binaries (perhaps a provider-specific tool etc) they will all at least have the same security and stability baseline as has been true for many years.
Q. Differences between Red Hat OpenJDK and AdoptOpenJDK?
Andrew Haley (Java Platform Lead Engineer, Red Hat) stated: “…we tweak our builds to use system libraries rather than bundled libraries and we make a few other distro-specific patches. Also, as a matter of policy, our distros are built from source.”
For a more detailed technical comparison of Red Hat OpenJDK (for Windows) and AdoptOpenJDK see Alex Kasko’s comment on Stack Overflow.
Q. If I stay on Oracle JDK 8 / 11, do I have to pay to get security and bug fixes?
For Oracle JDK 8, for personal desktop use, for development, testing, prototyping, demonstrating and with certain types of applications, then no. For most commercial use after the April 2019 update, then yes.
Q. If I stay on OpenJDK 8 / 11, do I have to pay to get security and bug fixes?
Not necessarily. As was the case with Java SE 6 and Java SE 7, Oracle works with the OpenJDK community to transition the leadership of OpenJDK update projects to other contributors. This has worked well for over a decade. Red Hat will continue this leadership in OpenJDK 8 and OpenJDK 11 with help from Oracle and other parties. This means important patches will get selectively backported. You then have the choice of taking downstream OpenJDK based binaries from a variety of providers for free, or as part of a paid support offering. There is an OpenJDK Vulnerability group which deals with 0-day exploits and CVE’s and ensures that fixes get out as quickly as possible.
Q. Will Oracle’s JDK 8 and 11 still be available for download (last public release)? For example, a company has software that only runs on Oracle’s JDK 8 and they provision a new machine after January 2019?
You can still download older versions of the Oracle JDK up to the point where the public updates stop. There is no reason to expect these archives to be removed. Moreover, Oracle JDK 8 continues to be free for personal desktop use, for development, testing, prototyping and demonstrating and with certain types of applications through at least 2020.
Q. If someone is using Oracle JDK 8 to run commercial software, after April 2019 do they need to purchase a license?
No. The user can continue to use Oracle JDK 8 indefinitely without paying. The only cost is if they want to get updates beyond April 2019, in which case they will need to purchase an “Oracle Java SE subscription”. This follows the usual “End of Public Updates” process which has been in practice for well over a decade. Also, note that Oracle JDK 8 continues to be free for personal desktop use, for development, testing, prototyping and demonstrating and with certain types of applications through at least 2020.
Q. What happens to Oracle Java Web Start after April 2019? Does it continue to run or at what point do you need to purchase a license?
Since Web Start is part of Oracle JDK 8 it will continue to work and can be used indefinitely without cost. As above if you need updates (bug fix and security patches) you will need to purchase a “Java SE subscription”. If your end users are consumers, they are covered for free until at least 2020. Oracle has stated that they will continue to support (i.e. provide commercial updates for) Java Web Start at least until March 2025. There is also IcedTea-Web as an alternative and Karakun is working on an OSS replacement for Web Start.
Appendix I — Signatories, Thanks and References
Special thanks go to the following folks who paved a road with their earlier blog posts. Much of the material in this document was collated (with permission) from these sources.
- Java Champions — A Community Body of Java Experts
- Martijn Verburg — Lead Author / Facilitator of this document
- Simon Ritter (Deputy CTO — Azul) — Eliminating Java Update Confusion
- Stephen Colebourne (Joda-Time author) — Java is still available at Zero Cost and Java 11 Options.
- Hendrik Ebbers (Co-founder Karakun) — Do I need to pay for Java now?
- Johan Vos (Co-founder Gluon) — JavaFX Release and Support Plans
- Many others!
Oracle via Donald Smith (Senior Director of Product Management)
- Faster and Easier User and Redistribution of Java SE
- Extension of Oracle Java SE 8 Public Updates and Java Web Start support
- The future of JavaFX and other Java Client Roadmap Updates
- Update and FAQ on the Java SE Release Cadence
- A Quick Summary on the new Oracle Java SE Subscription
- Oracle JDK Releases for Java 11 and later
Other notable folks
- Jonas Konrad — Java Support
The following Java ecosystem folks back this document as a fair and balanced record of the state of Java SE / OpenJDK and plans for free updates and/or paid support.
Person / Credentials
Martijn Verburg
AdoptOpenJDK co-lead, Java Champion, London JUG Leader, Member of JCP Executive Committee, Jakarta EE Steering Committee Member, CEO @ jClarity
Hendrik Ebbers
Java Champion, JUG Dortmund Leader, JSR EG member, Co-founder of Karakun
Ivar Grimstad
Java Champion, Malmö JUG Leader, JCP Executive Committee Member, EE4J PMC Lead, Jakarta EE WG Member
Markus Eisele
Java Champion
Heinz Kabutz
Java Champion, The Java Specialists’ Newsletter, JCrete Founder
Ivan St. Ivanov
Java Champion, Bulgarian JUG Leader, jPrime Conference Organizer, Virtual JUG Leader, VIDA Software co-founder
Stephen Colebourne
Java Champion, Creator Joda and ThreeTen projects
Trisha Gee
Java Champion, Sevilla Java User Group Leader, JCP Executive Committee Member, Java Developer Advocate for JetBrains
Josh Long
Java Champion, Spring Developer Advocate for Pivotal, best-selling book author and prolific speaker worldwide
Gail Anderson
Java Champion, Oracle Developer Champion, co-founder Anderson Software Group, Inc.
Justin Lee
Java Champion, JSR EG Member
Mattias Karlsson
Java Champion, JUG Leader, and Jfokus conference founder
Andres Almiray
Java Champion, JCP EC Member, Oracle Developer Champion, Hackergarten worldwide
Enrique Zamudio
Java Champion, JVMMX (Mexico City JUG), author of j8583, jAlarms, Ceylon to Javascript compiler
Alan Williamson
Java Champion, author, podcaster, CTO of MacLaurin Group
Maurice Naftalin
Java Champion, Oracle Developer Champion, author
Mark Heckler
Java Champion, Spring Developer Advocate for Pivotal, conference speaker, & published author
Kirk Pepperdine
Java Champion, jCrete cofounder, Performance tuning advocate, co-founder jClarity
Matt Raible
Java Champion, Web Developer, and Developer Advocate at Okta. Classic VWs Enthusiast.
Henri Tremblay
Java Champion, Montréal JUG & Devoxx4kids Québec leader, EasyMock and Objenesis lead developer, conference speaker
Cay Horstmann
Java Champion, author of “Core Java”
David Heffelfinger
Java Champion, Apache NetBeans Committer, Technical Author, Jakarta EE Consultant, and Instructor.
Josh Juneau
Java Champion, Apache NetBeans Committer, Jakarta EE Mojarra Committer, Technical Author, Podcaster
Jonathan Giles
Java Champion, Dukes Choice Award winner, Microsoft Cloud Developer Advocate, Co-founder Gluon
Ben Evans
Java Champion, former JCP EC Member, co-founder jClarity, author of “Java in a Nutshell” & “Optimizing Java”
Johan Vos
Java Champion, Oracle Developer Champion, Gluon co-founder
Thor Henning Hetland
Java Champion, Principal at Capra Consulting. Community leader Cantara, javaBin, JavaZone, Oslo Software Architecture and more..
Simone Bordet
Java Champion, JUG Torino co-leader, Jetty team member
Holly Cummins
Java Champion, Author of Enterprise OSGi in Action
Daniel Bryant
Java Champion, co-author of Continuous Delivery in Java, and leader within the LJC
Mohamed Taman
Java Champion, Oracle Groundbreaker Ambassador, JCP member, EGJUG leader. International speaker, Author of “JavaFX essentials”, “Getting started with clean code, Java SE 9”, “Hands-On Java 10 Programming with JShell”, and “Secrets of the Java Champion” Won Duke’s choice 2014, 2015 awards, & JCP outstanding adopt-a-jar participant 2013 awards.
Simon Maple
Java Champion, Oracle Developer Champion, Virtual JUG leader, Director of Developer Relations, Snyk.
Oliver Gierke
Java Champion, Spring Data Project Lead at Pivotal Software, Inc.
Jean-Michel Doudoux
Java Champion, author of “Développons en Java”
Michael Kölling
Java Champion, Creator of BlueJ and Greenfoot, author of ‘Objects First with Java’.
Mert Çalışkan
Java Champion, Director of OpsGenie Academy, Published Author, Speaker
Leonardo M R Lima
Java Champion, JSR Spec Lead
Cesar Hernandez
Java Champion, Senior Software Engineer at Tomitribe, Eclipse Foundation Committer, Guatemala Java User Group member, Speaker and board member of Latin America Virtual JUG JEspañol.
Rustam Mehmandarov
Java Champion, Chief Engineer, Leader of JavaZone, board member and former leader of javaBin — Norwegian Java User Group.
Paul Bakker
Java Champion, Senior Software Engineer at Netflix
Geir Magnusson Jr
Java Champion, Member Apache Software Foundation, CTO at fuboTV
Jorge Vargas
Java Champion, JUG Leader JavaUP — Mexico — Speaker and member of JUG JEspañol.
Bruno Souza
Java Champion, JUG Leader of SouJava
Ian F. Darwin
Java Champion, Developer, Author, Trainer, Mentor, Speaker. Author of O’Reilly Java Cookbook, Android Cookbook, etc.