javaone
我们刚刚在旧金山有了JavaOne的第二十版。 这将是我自2004年以来第十二次参加不间断的系列活动。最大的教训是什么,可以揭示Java的未来。
模块化斗争
自从Java 2007首次提到模块以来,已经花费了将近9年的时间,或者说,直到2016年9月JDK 9正式发布时为止。 实际上,自JSR 277 Java模块系统以来,已经有11年了 。 当我们考虑这一努力时,将需要十多年的活动和思考( 请参见何鸿tan的原始声明 )。 Oracle对JDK的模块化工作需要自己的传记。 马克·雷因霍尔德(Mark Reinhold)也许有一天会写它,也许它会成为21世纪神话般的人类月份。 有效地重写Java令人恐惧,以至于它遵循HIGH COHESION和LOOSE COUPLING花费了近十年的时间。 除了JDK工程师以外的其他所有人都应该感到非常害怕,尤其是如果您所涉及的业务拥有庞大的Technical DEBT。 许多机构负担不起升级,重写和重新排序旧式类,程序包,更不用说模块了。 确实,对于那些难以承受重压并仍然坚持使用经典Java(JDK 1.0至7.0)的企业而言,可维护性的成本将变得天文数字化。对于Oracle,他们没有选择支付开发,设计和体系结构的全部成本。整个Java平台和社区的利益,以便在将来变得越来越好。 当我们在2016年达到JDK 9 GA时,应该对Oracle表示极大的祝贺。
模块化与我们的未来
应用程序和JDK的模块化是新的谚语,我相信Java和实践的开发人员,设计师和架构师社区都有一个“ LINE-IN-THE-SAND”(又称DEMARCATION POINT或DISRUPTION LAYER),我们将在2016年通过模块化系统可以比JDK平台更快地进行更改。 如果Project Jigsaw的设计正确,则您不再需要与CORBA或IBM派生的老式java.util.Date和java.util.Calendar竞争。 从理论上讲,您应该能够替换这些模块服务,并在不需要它们时将其删除。 如果不需要Swing,则该模块可以使用,对于JavaFX和AWT(仅用于服务器部署)相同。 尽管保证了Java平台的向后兼容性,但这意味着有机会进行试验和提出新的想法。 我预计,对于招聘部门,JDK 9在2017年将成为CAMEL的绝招。 我相信没有人会想以更快的速度触碰Java SE 7或更早版本(经典Java)。 如果那里甚至有经典的Java提示,高级工程师都会查看您的工作规格并运行100英里。 您可以提供1000英镑/天的费用,为期6个月,但认真对待这些债务的人会试图重新模块化古老的Java代码,而当下一个从事这一行业的女性开始使用现代模块化Java框架时,获得丰富的经验,领先一步,在JDK 9上构建下一个伟大的事物。另一方面,模块化并不能解决技术上的麻烦。 如果您企业的关键任务软件是无懈可击的,那么除非行为发生敏捷变化,否则您将继续承受债务。 我认为,这就是Oracle JDK 9团队希望我们成为抢先体验的早期采用者,以便尽可能地测试其企业软件的原因。
增强了将Java推入云的能力
在JavaOne 2015上,有很多关于微服务和构建云企业应用程序的想法和会议演讲。 展览中有一些云供应商,例如JElastic,Red Hat,Pivotal和CloudFoundry。 Oracle发布了自己期待已久的云产品,称为Oracle Java Cloud 。 具有讽刺意味的是,他们的PaaS解决方案提供了与Oracle Coherence集群的服务器,该公司以前称为Tangasol。 Oracle前副总裁Cameron Purdy创建了这种早期的分布式网格和缓存解决方案,实际上,他的拥护者之一Brian Oliver早在2007年就参加了JAVAWUG BOF 26并就Coherence进行了演讲。
Kubernetes和Docker
Arun Gupta是讨论Kubernetes (Google的Linux容器集群)的三位技术演讲者之一。 有新的术语。 荚是共享IP和存储卷的Docker容器的并置组。 服务是一组Pod的单个,稳定的名称,还可以充当负载平衡。 标签名称值对已分配给容器。 在非正式的情况下,LIGHTWEIGHT与HEAVYWEIGHT之间的旧应用程序服务器营销战(通常采用Java EE与Spring的模式)在本次JavaOne会议上退居二线。 如果您碰巧使用Docker或Vagrant以及诸如Chef或Puppet之类的配置管理工具,您可能会吐口水,因为如果您要停止并(重新)启动通过部署从Soup到Nuts配置的虚拟机,配置文件,您不在乎WildFly服务器有多轻或有多重? 更重要的是要知道可以使用已部署的ACME.WAR启动WildFly 8.2,并且HTTP Undertow模块已连接到秘密端口4123,该端口从外部映射到某些虚拟机上的端口80。 如果WAR文件是10MB或1MB,则您不再关心WAR文件的实际大小。
梦想微服务
戴安娜·马什(Dianne Marsh)关于NetFlix开发人员的讨论完全结束了。 许多人都在考虑这些想法,我怀疑很少有很少的组织能够在企业内部实践这些想法,并且很少有敏锐的商业支持。 微服务需要运营团队在跨职能部门(通常跨部门)工作。 在许多传统的美国和英国投资银行,其他大型商业机构,零售组织,数字设计机构中都可以找到SILO驱动工程,这是对Micro服务的厌恶。 因此,请继续做梦,如果您幸运或不幸地成为其中的一部分...最好的希望根本不是微服务,但您可以重新考虑您的MONOLITH并尝试使用COMPONENTISED APPLICATION,如果可以的话在您的企业体系结构中,您应该能够获得模块化的MONOLITH,它比(意大利面条内置的)MONOLITH更好。
Scala和Groovy
–今年,关于替代JVM语言的讨论较少。 我参加了Ted Malaska的Apache Spark演讲,这很有趣。 我还参加了Groovy中Cedric Champeau的“领域特定语言”演讲。
JavaFX逐步移动友好
JavaFX在台式机上像往常一样工作-令人惊讶的是,在今年的会议上,围绕JavaFX的主题没有创新,展示了新功能。 但是,由于Swing处于维护模式已经有好几年了,因此JavaFX的采用比以前更强。 Gluon正在投资对JavaFX的移动跨平台支持。 Gluon已经接管了将JavaFX应用程序移植到iOS和Android的工作。 对于台式机,JavaFX可能需要富文本编辑组件。 对于移动设备,有JavaFXPorts 。 我怀疑该软件团队的下一个巨大工作就是JavaFX 3D和媒体库的帮助。
JavaScript影响
AngularJS在客户端对JavaScript编程提供了一些支持。 在我自己的Digital Java EE 7演讲中,我演示了AngularJS案例工作者应用程序,并且在AngularBeans上还有另一个竞争性演讲,将AngularJS与JSF混合在一起。 Oracle还宣布了自己的JavaScript扩展工具包 ,该工具包基于Knockout.js,JQuery,JQuery UI和RequireJS。 Kito Mann在Polymer网站组件上进行了演讲。 当然,对于那些有兴趣在JVM服务器端运行JavaScript的企业,也有Nashorn技术会议。
无容器构建
人们肯定对Spring Boot感兴趣,并且可能是WildFly Swarm ,正是出于与可能在微服务上出售相同的原因。 显然,最大的区别是围绕Hot JVM类重载和动态资源的技术支持。 这些扩展解决方案与应用服务器中的WAR部署投资背道而驰,这并不奇怪,尽管该规则的例外是带有Scala(和Java)的Play Framework。 诸如JetBrain的IDEA 15和Netbeans 8.1之类的IDE允许通过HOT更改进行交互式和实验性开发。 dvelopers可以对Java代码进行合理的更改,更重要的是可以更改CSS,页面viewS和JavaScript文件,而无需重新启动应用程序。 借助Micro服务及其亲密的同僚,他们在WildFly Swarm和Spring Boot中构建了无容器构建,这种高度交互的模式(我在Bret Victor中进行频道介绍-在这里发明原理 )被取消了。 在WildFly Swarm的情况下,最大的问题是它们还没有爆炸式,可动态重装的ShrinkWrap实现,它可以允许JVM重载类和Web资源。 唯一的解决方法是可能用APPLE-IDIOMATIC-SPLIT-TEAMS-SECRET方法编写应用程序。 用户界面设计团队开发了一个新的前端,该前端负责按标题,标题,图形和描述显示产品列表。 服务器端团队编写远程端点服务以查询数据库。 前后团队在REST API或Web界面上达成共识,但他们对产品本身或说明一无所知。 他们将使用模拟数据进行测试。 高管将在发布前用Apple iPhone Invisible Edition 5150以及所有相关信息,标题,标题,英雄图形,配件,描述和价格填充产品数据库。 对于苹果公司来说,这是一个很好的解决方案,因为它是一家Kool-Aid公司,对较小的团队,中小型企业甚至一人(和一人򊰥�通常,您需要一个完整的堆栈解决方案,您可以从头到尾完全使用它,反之亦然。无容器则非常适合RESTful端点和服务器。 代码Hale的DropWizard向我们展示了如何实现这一目标。对于Java的Web前端工作还不太好(尚未)。
詹姆斯写Java
Mike Duigou的演讲James编写Java:我通过阅读James Gosling的代码[CON3563]所学到的知识 –这真是一场精彩的会议。 我很高兴看到这个直播,因为它让我想起了不要在编码中沾沾自喜的想法。 詹姆士·高斯林(James Gosling)绝对会继续用自己的知识来扩展编码。 还有改进的空间。
Java至少还有20年的生命。 从23岁(初级工程师)到63岁(ACME / PEABODY的首席架构师和静态代码),完全有可能在Java平台上工作。 我认为这当然是可以实现的。 Java编程语言和JVM之外的其他行业实践将对该生态系统产生深远影响。 硬件将不断扩展。 JVM将不得不处理1TB RAM和垃圾回收。 确实,这是JVM工程团队的下一个增长领域。 JDK 10应该希望看到值类型来帮助进行内存分配。 在服务器端,云仍然是新的前沿领域,因为它仍不确定蓝领Java开发人员将如何决定云的价值。
在用户体验方面,JavaFX使富客户端接口的寿命延长了。 JavaScript非常适合Web浏览器和HTML5,CSS元素,但是对于重型图形动画,声音和媒体渲染,富客户端是应用程序的必需。 毕竟,本机移动开发中可能有一个冗长的尾巴,Java和JavaFX只能位于LOCKED-IN平台两个据说不可逾越的WALL GARDENS之上。 如果Java坐着,潜行并潜伏在那里,那么机会就来了,它偶尔会做一次,然后继续前进。 但是,将需要专门的发烧友和小型敏捷的创新型初创公司保持压力,并确保移动开发的UNIVERSALITY继续进行。 我相信这是有机会的,因为移动芯片组将在10年内成倍增长。 看看JavaFX和其他JavaScript桥接解决方案在短短几年内(更不用说20年)将我们带到何处,将会很有趣。
Java MODULE系统是巨大的机会。 它是最终的DESIGN-FOR-REPLACEMENT功能,而不是Java编程中的功能,而是Java虚拟机和JDK发行版中的功能。 我们,开发人员,设计师和建筑师是否会永远使用它? 我们将在SOLID的修改中使用它吗? 还是我们会以某种方式滥用它? 模块化可能位于标尺的两个相对端,并且比例不同:物联网和微服务分布式应用程序模块。 就硬件和软件而言,未来很难预测。 我们唯一能做的就是参与其中,并不断前进。 让我们一起享受旅程吧。
+ PP +
Arun Gupta,用于通过微服务和容器重构Java EE应用程序(CON1700)
拉斐尔·贝内维德斯(左)和安东尼·杜randint(右)
Stephen Chin在Raspberry Pi,Oracle Demogrounds和JCP Hackergarten上焊接
徽章2015
这是给Java冠军和Googler同事Kevin Nilson的。 凯文的儿子正在JavaOne 2015的Ignite会议上讲话!
翻译自: https://www.javacodegeeks.com/2015/11/javaone-2015-the-twentieth-edition-ten-takeaways.html
javaone