注:此问题来自2014年。截至Java 11 OpenJDK和OracleJDK正在融合。

Oracle和OpenJDK之间有什么关键的区别吗?

例如,垃圾收集和其他JVM参数是否相同?

GC在两者之间的工作方式不同吗?


当前回答

根据oracle博客,oracle JDK发布Java 11及更高版本

从Java 11开始,Oracle将根据开源GNU通用公共许可证v2、Classpath例外(GPLv2+CPE)以及商业许可证为那些将Oracle JDK作为Oracle产品或服务的一部分或不希望使用开源软件的人提供JDK版本。这种使用开源许可证和商业许可证的组合取代了历史上的“BCL”许可证,该许可证包含免费和付费商业条款。

每个许可证将提供不同的版本,但这些版本在功能上是相同的,除了一些外观和包装上的差异外,将在下面详细描述。

从BCL到GPL

十多年来,Oracle Java SE技术的二进制代码许可证(“BCL”)一直是Oracle Java SE的主要许可证。BCL允许在某些条件下使用,无需支付许可费。为了简化今后的工作,Oracle从Java9开始提供开源许可的OpenJDK版本,使用与Linux平台相同的许可模型。如果您习惯于免费获取Oracle Java SE二进制文件,那么您只需继续使用jdk.Java.net上提供的Oracle OpenJDK版本即可。如果您习惯了将Oracle Java SE的二进制文件作为Oracle商业产品或服务的一部分,那么您可以继续通过My Oracle Support(MOS)和其他位置获取Oracle jdk版本。

功能相同且可互换。。。

Oracle的BCL许可的JDK历史上包含OpenJDK版本中没有的“商业功能”。然而,正如所承诺的,在过去一年中,Oracle为OpenJDK社区提供了这些功能,包括:

Java飞行记录仪,Java任务控制,应用程序类数据共享,以及ZGC。

因此,从Java11开始,OracleJDK版本和OpenJDK版本将基本相同。

……但在化妆品和包装方面存在一些差异

仍然存在少量的差异,有些是故意的,有些是表面的,有些只是因为需要更多的时间与OpenJDK贡献者讨论。

Oracle JDK 11在使用-XX:+UnlockCommercialFeatures选项时发出警告,而在OpenJDK中,此选项会导致错误。这个选项从来不是OpenJDK的一部分,现在添加它也没有意义,因为OpenJDK中没有商业功能。这一差异仍然存在,以便使Oracle JDK 10和早期版本的用户更容易迁移到Oracle JDK 11和更高版本。Oracle JDK 11可以配置为向“高级管理控制台”工具提供使用日志数据,该工具是一个单独的商业Oracle产品。我们将与其他OpenJDK贡献者合作,讨论此类使用数据在未来版本中如何在OpenJDK中有用(如果有的话)。这一区别主要在于在做出此类决策之前,为Oracle客户提供一致的体验。javac--release命令对Java 9和Java 10目标的行为不同,因为在这些版本中,Oracle JDK包含一些其他模块,这些模块不是相应OpenJDK版本的一部分:javafx.basejavafx控件javafx.fxmljavafx.graphicsjavafx.mediajavafx.webjava.jnlpjdk.jfr公司jdk.管理.cmmjdk.management.jfrjdk.management资源jdk.packager.servicesjdk.snmp

这种差异仍然存在,以便为特定类型的遗留使用提供一致的体验。这些模块现在可以作为OpenJFX的一部分单独提供,现在在OpenJDK和Oracle JDK中都有,因为它们是Oracle为OpenJDK提供的商业功能(例如,Flight Recorder),或者从Oracle JDK 11中删除(例如,JNLP)。

java-version和java-fullversion命令的输出将区分OracleJDK版本和OpenJDK版本,以便支持团队能够诊断可能存在的任何问题。具体来说,在Oracle JDK 11版本中运行java-version会导致:

java 11 2018-09-25

Java(TM)SE运行时环境18.9(内部版本11+28)

Java HotSpot(TM)64位服务器VM 18.9(内部版本11+28,混合模式)

对于OpenJDK 11版本:

openjdk版本“11”2018-09-25

OpenJDK运行时环境18.9(版本11+28)

OpenJDK 64位服务器VM 18.9(内部版本11+28,混合模式)

OracleJDK一直要求第三方加密提供程序由已知证书签名。OpenJDK中的加密框架具有开放的加密接口,这意味着它不限制可以使用哪些提供程序。Oracle JDK 11将继续要求有效签名,Oracle OpenJDK版本将继续允许使用有效签名或未签名的第三方加密提供程序。OracleJDK11将继续包括安装程序、品牌和JRE打包,以获得与传统桌面使用一致的体验。Oracle OpenJDK版本目前以zip和tar.gz文件的形式提供,同时正在考虑其他分发格式。

其他回答

Oracle JDK 11和OpenJDK 11之间剩下的几个外观和包装差异可以在这篇博文中找到:

https://blogs.oracle.com/java-platform-group/oracle-jdk-releases-for-java-11-and-later

简而言之:

Oracle JDK 11在使用-XX:+UnlockCommercialFeatures选项时发出警告,它可以配置为向“高级管理控制台”工具提供使用日志数据,它总是要求第三方密码提供者由已知证书签名,它将继续包括安装程序、品牌和JRE打包,而javac-release命令对于Java 9和Java 10目标的行为略有不同,并且java-version和java-fullversion命令的输出将区分OracleJDK版本和OpenJDK版本。

对于Java 8、Oracle JDK与OpenJDK,我的主要区别是:

OpenJDK是Java Standard Edition平台的开源实现,Oracle和开放Java社区对此做出了贡献。OpenJDK根据许可证GPL v2发布,其中Oracle JDK根据Oracle二进制代码许可协议获得许可。实际上,OracleJDK的构建过程是从OpenJDK源代码构建的。因此,OracleJDK和OpenJDK之间没有主要的技术差异。除了基本代码之外,OracleJDK还包括Oracle的Java插件和Java WebStart的实现。它还包括第三方开源和开源组件,如图形光栅化器和Rhino。OpenJDK字体渲染器和Oracle JDK飞行记录器是Oracle JDK和OpenJDK之间显著的主要区别。Rockit是Oracle的JVM,从JavaSE7、HotSpot和JRockit合并为一个JVM。所以现在我们只有合并的HotSpot JVM可用。有些情况下,人们声称他们在运行OpenJDK时遇到了问题,当切换到OracleJDK时,问题得到了解决。Twitter有自己的JDK。像Minecraft这样的软件希望使用Oracle JDK。事实上,他警告说。

有关差异的完整列表,请参阅源文章:Oracle JDK与OpenJDK和Java JDK开发过程

我的理解是,OracleJDK不能用于生产,因此我不能合法使用它(不付费),用于我为公司构建的web应用程序。我必须使用OpenJDK。如果我错了,请纠正我!来自本文。

从Java 11开始,Oracle JDK仅限于开发和测试环境。Oracle JDK只能在以下情况下用于生产你购买了商业支持。相反,Oracle将提供Java基于OpenJDK免费构建,可用于生产。但是对于官方的Oracle JDK,真正的路线图如下所示:

更新:我错了。我可以免费使用OracleJDK,但6个月后不会获得安全更新,我们必须承担风险。看看上面链接的文章部分“新发布的列车对我的公司意味着什么?”。

Oracle将每三年发布一次,而OpenJDK将每六个月发布一次。Oracle为其版本提供长期支持。另一方面不过,OpenJDK只支持在下一个版本之前对某个版本所做的更改版本发布。Oracle JDK根据Oracle二进制代码许可协议获得许可,而OpenJDK具有GNU通用公共许可证(GNUGPL)版本2,链接异常。Oracle产品具有Flight Recorder、Java Mission Control和应用程序类数据共享功能,而OpenJDK具有字体渲染器功能。此外,Oracle还有更多垃圾收集选项以及更好的渲染器,Oracle JDK由Oracle Corporation完全开发OpenJDK由Oracle、OpenJDK和Java社区开发。然而,像红帽、Azul Systems、IBM、,苹果股份有限公司、SAP AG也积极参与其发展。


从Java 11转向大变革

Oracle将更改其历史上的“BCL”许可证,同时提供开源和商业许可证

Oracle的Java 11工具包在使用-XX:+UnlockCommercialFeatures选项时发出警告,而在OpenJDK版本中,该选项会导致错误Oracle JDK提供了一种配置,用于向“高级管理控制台”工具提供使用日志数据Oracle一直要求第三方加密提供程序由已知证书签名,而OpenJDK中的加密框架具有开放的加密接口,这意味着可以使用哪些提供程序没有限制Oracle JDK 11将继续包括安装程序、品牌和JRE打包,而OpenJDK版本目前以zip和tar.gz文件的形式提供javac–release命令对Java 9和Java 10目标的行为不同,因为Oracle版本中存在一些附加模块java-version和java-fullversion命令的输出将区分Oracle版本和OpenJDK版本



更新日期:2019年8月25日



有关更多详细信息,oracle vs openjdk

对于Java 8,AMIS技术博客于2018年11月发布了一个针对各种JVM上托管的反应式(非阻塞)Spring Boot REST应用程序的有趣性能基准,该基准显示了以下差异:

OpenJDK的CPU使用率高于OracleJDK,OpenJDK的响应时间略低于OracleJDK,OpenJDK的内存使用率高于OracleJDK,

有关详细信息,请参阅源文章。

当然,YMMV,这只是基准之一。