【编者按】对于前不久 Oracle 裁掉了一部分 Java 布道师,近日一位 Oracle 前高管称其为该机构对Java的「计划报废」。如果这个计划是属实的,那么对于寻常的开发者、已经采用了 Java 的公司、预备选择 Java 作为基础的创业者,究竟又会产生什么样的影响?近日,Jason Whaley 在 Dzone 上进行了详细的分析。本文由 OneAPM 工程师编译整理。

几个月前,Oracle 裁减了部分 Java 布道师。不久之后,一位 Oracle 前高管在发送给Infoworld 的邮件中称此举为「计划中的报废(planned obsolescence)」。

一位负责 Java 的 Oracle 前高管在周二发给 InfoWorld 的这封邮件中声称了解 Oracle 公司内部信息。邮件称 Oracle 正在转型为云公司,以期与 Salesforce 竞争。而且,「Java 已经完全失宠」,主题栏的原文为「Java——计划中的报废」。

邮件还说,Oracle 不想给竞争对手更多资源,不想分享创新成果。Oracle 正在缩减对 Java EE (企业版)的投入,同时它也不希望别的公司接手 Java 或 Java EE,而且它正逐步将 JCP (Java Community Process) 打入冷宫。邮件称:“它们抱着赢者通吃的想法,不再热衷于合作”。「WebLogic 的专利申请将会逐步完成,同时,也会推出一个专利的微服务平台。」WebLogic 是 Oracle 在2008年收购 BEA Systems 时得到的 Java 应用服务器。

如果以上陈述有一半属实,那 Oracle 的想法和计划真是相当吓人。现在,将上面的陈述与下面的事实一起考虑。事实上,Oracle 掌握了 Java 大部分的所有权。

  • Java 语言、Java 虚拟机以及标准的 API 都是遵循 GPL 许可的开源资源。
  • 在收购了 Sun Microsystems 之后,Oracle 成为该知识产权的所有者。
  • Oracle 勇于通过代价高昂的法律诉讼维护其知识产权——它与 Google 围绕 Android 的官司就是证明。
  • 那次官司的结果是法律不支持 Java API 被复制或分支(copy/fork),也不支持通过封装或重命名的方式移为他用。
  • Java Community Process 是目前唯一可以改变该语言核心或标准 API 的方式。
  • 第三方供应商若想开发 Java 工具并大量发售,必须获得(大多是以购买)Oracle 的许可。

最后,将以上所有事实与 Oracle—— Java 唯一拥有者的未来计划一起考虑。

  • 不打算对 Java 进行有意义的更新
  • 不觉得有必要布道其产品以提高采用量或鼓励创新应用
  • 只因为 Java 是其他专利产品的开发基础才觉得它有用

是不是觉得有点夸大其实?可能是吧。但如果 Oracle 真打算将 Java 平台投入维护模式,以上想法并非无稽之谈。那么,对于每天依赖 Java 或 JVM 工作的寻常开发者而言,这冷酷的前景意味着什么呢?对于那些以 Java 技术为软件基础架构支撑的公司而言,又意味着什么呢?对那些正准备用 Java 编写产品原型或 MVP(最小化可行产品)的初创者,又如何呢?前面所有问题的答案是:“没有任何影响。至少现在是这样。”

对于寻常的开发者

Java 仍旧是当下部署最广泛、使用最普遍的平台语言。我掌握的一手资料显示,今年的 JavaOne 大会依旧充满生机。现今主流的基础架构还是以 Java 为基础构建。在 TIOBE(编程语言排行榜)上,Java 还是跟 C 一起,交替处于榜首。

围绕 Oracle 裁减布道师的阴云与猜测并不会对雇主们的 Java 或 JVM 技能需求产生任何影响,今天不会,明天不会,明年也不会——恐怕要有好一阵才有影响。即便 Java 语言和标准 API 的普及率下降了,越来越多的新语言正以更快的速度基于 Java 平台进行开发,那些(更普遍的情况)自带 API 的语言,往往也是基于标准 API 的。

以上所有开发都依赖于该家喻户晓的热点 JVM,那 Oracle 对其知识产权的控制又如何呢?即便 Java 不再流行,仍有 Azul 之类的公司愿意向 Oracle 购买证书从而通过其兼容的 JVM 赚钱,比如他们的商业产品 Zing 以及免费的 Zulu。

对于寻常的开发者,这个新闻无须挂怀。即便是那些将全部职业生涯都赌在 Java 这一种平台的开发者,这么做虽然比较不明智,但也不用担心。围绕 Java 生态系统的技能与知识需求不会在短时间内消失。

对已经采用了 Java 的公司

与日常开发者差不多,变化也不大。之前就在基础机构中采用了 Java 的公司早就赌定 Java 能帮助其完成既定的商业目标——即使该平台的背后支持是传说中「邪恶」的 Oracle,或更早之前,一直都穷困潦倒的 Sun Microsystems。 这些全面展开的系统既然能实现商业目标,就不能因为它们建立在 Oracle 发布的平台之上,而沦为抛弃对象。

一般而言,在短时间内重写或替代重要基础架构中的 Java 组件的成本与风险远远大于回报。此处的回报是在未来,你新采用的平台变得非常普遍从而最终降低成本、提高业务敏捷性。重写并替换工作系统是非常危险的冒险——只要看看 Netscape 的例子就知道了。即便一个公司顺利地完成了迁移,回报也只能在多年以后得以实现。

若不管替换工作系统的问题,为了避免未来陷入遗留系统的困境,已经采用 Java 的公司组织可以将基础架构迁移至微服务模型(microservices model)以降低风险。微服务策略也是一把双刃剑,该话题在软件开发领域还处于热烈的讨论阶段,包括何时、何处、如何部署微服务架构。但若是担心与 Oracle 停止开发的平台绑定的潜在风险,机警的公司至少可以通过微服务,逐步地,替换或孤立以 Java 为基础的服务组件。

新的项目该何去何从呢?

如果你正在筹备新的科技公司或启动内部新项目,并且觉得 Java 是合适的技术选择,就需要讨论一下该不该以 Java 生态系统为基础。讨论的焦点还是集中在可能产生的技术债务(technical debt)。在选择平台时这类技术债务完全无法避免——区别在于这些债务的回报如何。

选择 Java 平台意味着获得健康广阔的生态系统,以及丰富的知识、劳动力与相关产品。作为交换,由此带来的技术债务在于,该平台也许无法适应未来的技术演进,因为其所有者不打算继续开发它。现在,你或许可以开发出健康的产品,尽管未来会的开发成本会越来越高,甚至牺牲未来的业务敏捷度。

其他的平台选择都有各自的技术债务。但简而言之,各有各的不同。比如:

  • 选择 Node.js 平台意味着缺少丰富的稳定生态系统。但该平台非常活跃,欣欣向荣,可能会持续发展很长时间,而且 Node.js 人才也越来越多。
  • 选择 Ruby(很可能与 Rails 一起)平台意味着能以合算的成本快速建立起工作系统的基础架构,但坏处是扩展性不佳。
  • 你也可以选择 Microsoft/.NET 生态系统,该系统拥有一些与 Java 平台相似的优点,但缺点是你的公司命运会与另一个企业软件巨头的选择绑定。

……还有许多其他选择,每个选择都是利弊权衡的问题。

简而言之,是否选用 Java 平台作为新项目的基础平台很大程度上是个人决策。Oracle 可能厌倦了 Java,但这是否应该影响这个决策呢?当然应该。但是,这不该是唯一的考虑因素。尤其是借助 Java 生态系统建立项目,能可观地提高项目成功的机会。

原文链接:Even if Oracle is Losing Interest in Java, Should You Worry?

OneAPM for Java 能够深入到所有 Java 应用内部完成应用性能管理和监控,包括代码级别性能问题的可见性、性能瓶颈的快速识别与追溯、真实用户体验监控、服务器监控和端到端的应用性能管理。想阅读更多技术文章,请访问 OneAPM 官方博客

如果Java 失宠于Oracle,那么未来会怎么样?的更多相关文章

  1. java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 错误的解决办法

    java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 错误的解决办法 (2011-05-05 16:08:05) 转载▼ ...

  2. myeclipe eclipse 常遇问题:Some projects cannot be imported 、java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver、The file connot be validate

    1.Some projects cannot be imported because they already exist in the workspace 2.Some projects were ...

  3. 24、jQuery常用AJAX-API/Java调用MySQL / Oracle过程与函数

      1)掌握jQuery常用AJAX-API 2)掌握Java调用MySQL / Oracle过程与函数 一)jQuery常用AJAX-API 目的:简化客户端与服务端进行局部刷新的异步通讯 (1)取 ...

  4. Oracle03——游标、异常、存储过程、存储函数、触发器和Java代码访问Oracle对象

    作者: kent鹏 转载请注明出处: http://www.cnblogs.com/xieyupeng/p/7476717.html 1.游标(光标)Cursor 在写java程序中有集合的概念,那么 ...

  5. java.lang.ClassCastException: oracle.sql.CLOB cannot be cast to oracle.sql.CLOB

    错误现象: [framework] 2016-05-26 11:34:53,590 -INFO  [http-bio-8080-exec-7] -1231863 -com.dhcc.base.db.D ...

  6. java 实现往oracle存储过程中传递array数组类型的参数

    注:本文来源于 <  java 实现往oracle存储过程中传递array数组类型的参数  >最近项目中遇到通过往存储过程传递数组参数的问题, 浪费了N多个小时,终于有点头绪. 具体的代码 ...

  7. Java 测试连接Oracle数据库是否成功,ojdbc7.jar包下载

    需要用到的jar 包: 链接:https://pan.baidu.com/s/1I1pC2f81IvbphZ6tWpVFOg 密码:uq0u 测试结果: package pkg; import jav ...

  8. java.lang.ClassNotFoundException:oracle.jdbc.OracleDriver

    在使用JDBC时经常碰到java.lang.ClassNotFoundException:oracle.jdbc.OracleDriver问题 这是jvm找不到驱动类文件,可能是以下原因: 没有导入驱 ...

  9. LoadRunner调用java函数测试oracle

    LoadRunner调用java函数测试oracle 测试oracle的方法有很多,可以使用loadrunner的oracle协议直接调用oracle进行测试,也可以调用开发的java程序对oracl ...

随机推荐

  1. CSS之生成全屏背景图片

    在CSS中背景图片的填充方法: background-position:x,y(背景图片x,y轴的定位) background-repeat:no-repeat(不平铺) background-rep ...

  2. JSP之初识

    JSP是“java server pages”的缩写,java是一种编程语言,jsp只是相当于java里面的servlet部分,所以JSP技术是以Java语言作为脚本语言的. JSP这门技术的最大的特 ...

  3. asp.net C#数据导出Excel实例介绍

    excel导出在C#代码中应用己经很广泛了,我这里就做些总结,供自己和读者学习用. Excel知识点. 一.添加引用和命名空间 添加Microsoft.Office.Interop.Excel引用,它 ...

  4. 删除织梦所有待审核稿件sql语句

    先提醒一下 archives是dedecms主表addonarticle 新闻信息表 在dede后台"系统->SQL命令行工具"运行下以命令即可(注意,运行后未审核的数据全被 ...

  5. Cocos2d-x加速度计实例:运动的小球

    下面我们通过一个实例介绍一下如果通过层加速度计事件实现访问加速度计.该实例场景如下图所示,场景中有一个小球,当我们把移动设备水平放置,屏幕向上,然后左右晃动移动设备来改变小球的位置. 下面我们再看看具 ...

  6. 关于iOS9中配置App Transport Security(应用程序传输安全协议)

    在 在info.plist中,进行上面的配置就行了,注意的是,那个网址,你需要访问什么网址,就填写什么网址就行了. NSTemporaryExceptionAllowsInsecureHTTPLoad ...

  7. eclispe 出现超内纯错误

    刚开始以为只要修改tomcat的最大最小内存就可以,结果还是报错,后来才懂需要在eclipse.ini文件中修改 -Xms256m-Xmx512m的值改大些,增加虚拟机运行的内存空间 刚开始最小值只有 ...

  8. 服务器发布WebService返回DataTable

    初始化Datatable时,需要为Datatable命名.否则在客户端使用时,会报“datatable不能序列化...”导致表格无法从服务器端读取到. 例如: 服务器端: DataTable dt = ...

  9. 结构体的malloc与数组空间

    结构体的malloc 如果结构体中有指针,对结构体的malloc 和其指针成员变量的malloc是没有关系的 结构体malloc的是存储自己地址的 忘记了面试常考试的sizeof的几个主要点 ==== ...

  10. 鼠标按键自定义软件-X-Mouse Button Control

    转载说明 本篇文章可能已经更新,最新文章请转:http://www.sollyu.com/mouse-button-x-mouse-button-custom-software-control/ 说明 ...