应用容器云:接过Java EE的枪

本文根据DCOS联盟第4期线上分享整理而成

 

讲师介绍
宋潇男

普元云计算架构师

 

 

  • 曾任职华为,负责云计算产品与解决方案的规划与管理,十年以上分布式系统和中间件技术经验,熟悉HPC、同格计算、云计算实战。

 

主题大纲:

1、回顾Java EE的发展

2、揭示Java EE的根本性缺陷

3、从Java EE的角度看应用容器云

4、对未来的展望

 

大家好,首先自我介绍一下。

 

 

我来自普元软件,对Unix和云计算技术比较熟悉,而所在公司的传统业务是中间件,在这个背景下,我对眼下的容器热有着一些不同的看法,今天与大家分享。

 

老实说,今天的观点如果放在一年前,我不大敢讲,会比较有争议。最近看到有人也提出类似观点,所以我也整理了一下,拿出来分享。相信争议还是会有,希望能与大家共同探讨,也能进一步完善我的想法。

 

开始之前,首先需要明确下什么是Java EE,我直接引用了官方说明,不做翻译。

 

 

这里面有几组关键词,第一组是Platform、API and runtime,说明Java EE是远比Java语言范畴广泛的东西,今天所谈的Java EE的问题,基本上也和Java语言无关;第二组是large-scale、multi-tiered、scalable、distributed,这是Java EE的主攻方向,今天谈的问题主要也出在这里;第三组是modular components running on an applciation server,说明了Java EE的实现形态是应用服务器和一组运行在应用服务器上的组件。

 

下面看下Java EE的技术标准:

 

 

Java EE由一系列技术标准组成,这里面有我们熟悉的用于定位和访问资源的JNDI、用于描述Web Service的WSDL、用于安全方面的JAAS、用于消息传递的JMS等等。这里不展开讲,后面会看到这些Java EE技术标准,或者说是Java EE的API和“子系统”,在应用容器云里,会以基础服务的形式体呈现。

 

下一页是Java EE的一组实现,其实就是一系列应用服务器。

 

 

这个图来自IBM的竞争分析资料,稍微有一点美化自家产品WebSphere的味道,不过总体来说还算客观。

 

WebSphere确实在技术上最完整的实现了Java EE标准,在架构上可以支持最大的系统规模,就像图中所示,hundreds of servers,虽然很少见到上百个节点的WebSphere集群,但是WebSphere在架构设计上确实考虑到了这么大的规模。

 

既然WebSphere这么强,那我们就来打开看下WebSphere。

 

首先看下WebSphere的架构图,可以看到,Java EE的API作为一系列子系统运行在WebSphere中。

 

 

再看一下WebSphere的概念图:

 

 

WebSphere的主要概念有:

  • Application Server:即一个应用服务器实例;
  • Node:一个操作系统实例,里面可以运行多个Application Server;
  • System:可以认为是一个物理机,通过虚拟化,上面可以运行多个操作系统实例,即多个Node;
  • Cell:一组执行相似任务的Node,作为一个管理域统一管理。

 

这样的概念层次可以支持大规模的应用服务器集群,考虑的确实比同类产品要全面。

 

接下来看一下WebSphere如何管理large-scale multi-tiered系统。

 

 

只需要通过管理节点上传你的应用EAR,WebSphere就会帮你把应用部署到集群中所有Application Server实例上,可以在单一入口管理整个集群,还可以帮你管理前端的Web Server和后端的数据库。

 

看起来很美好,不是吗?然而,事实上不是这样。

 

现在我们来看一下Java EE,或者说Java EE的技术实现 —— 应用服务器的四大问题。

 

  • 第一个问题,资源隔离。

 

应用服务器实例运行在单一JVM上面,而JVM无法隔离CPU、内存、IO等资源,所以一个应用有问题、或者是应用的某个模块有问题,都会造成应用服务器上的所有应用无法正常运行,有时候还会影响同一操作系统上的其他应用服务器。所以现状往往是,一个操作系统内只运行一个应用服务器,一个应用服务器上只运行一个应用,失去了应用服务器作为基础架构和资源池的意义

 

  • 第二个问题,依赖管理。

 

应用服务器一般只能管理三层或者四层系统,对图中这种分布式系统无能为力,还记得最开始讲的Java EE的主攻方向里有distributed系统吗?实际上好像不是这么回事,或者说现在的分布式系统比起当年已经出现了根本性的变化。

 

  • 第三个问题,与应用紧耦合。

 

 

如图所示,应用服务器实际上已经变成了应用的一部分,而不是应用的基础设施。

 

  • 第四个问题,CI/CD不友好。

 

 

Java EE应用服务器过于庞大,很难纳入CI/CD流程。为什么要把应用服务器纳入CI/CD流程呢?前面说了,应用服务器实际上是应用的一部分,如果不纳入CI/CD流程,就会经常出现“在我这里能用,在你那里就不能用了”等看似琐碎、却影响很大的问题。

 

CI/CD都做不好,那怎么做DevOps呢!

 

这里可能有同学会说,可以用Tomcat、Jetty或者Spring Boot嘛。是这样,不过这些已经不是Java EE应用服务器了,使用嵌入式应用服务器是个很好的选择,但是这个时候,应用服务器就完全不具备large-scale、multi-tiered、scalable、distributed系统的管理能力了,后面可以看到,这些能力将由应用容器云提供。

 

上述这些Java EE意图解决却没有解决好的问题,应用容器云都可以很好地解决,所以才有了本次分享的题目:《应用容器云,接过Java EE的枪》。

 

 

使用容器技术配合微服务模式,Java EE的那些“子系统”以进程的方式运行在容器之中,可以做到很好地资源隔离并根据负载进行扩展。应用容器云标配的服务注册能力,可以比Java EE更好地解决当今分布式系统的依赖问题,应用容器和运行环境的耦合性很低,应用容器镜像高内聚而且体积适中,可以很容易的纳入CI/CD流程,Java EE的四大问题迎刃而解。

 

 

对比Java EE,应用容器镜像就像是更广义的“WAR”或者“EAR”,如果运行Java应用,镜像里可以包含应用本身、嵌入式应用服务器和应用在操作系统层面的各种依赖。

 

 

应用容器云就像是更广义的Java EE Platform,或者说是更广义的“应用服务器”,可以为各种语言和类型的应用提供Runtime并很好的将它们管理起来。

 

 

Java EE的“子系统”,在应用容器云中以基础服务的形式提供。

 

 

这些基础服务提供和Java EE API相似的能力,并且可以做得更好。

 

普元的数字化企业云平台正在紧张的开发之中,在此我对我司的产品和应用容器云这一产品形态做个展望。

 

 

应用容器云将完成Java EE未竟的事业。

 

最后我们来看一下Gartner的一个说法:

 

 

和我们的感受一样,与基于虚拟化的云平台,主要由运维人员参与的状况完全不同,这一波基于容器的云平台热潮由开发者推动,我个人也非常希望更多的开发者能够参与到这次变革之中。谢谢大家!

 

Q&A
 

Q1: 配合容器技术,Java EE的一些问题可以迎刃而解。我请问一下,贵公司的大数据相关应用(主要也都是Java相关),怎么与容器技术结合?

A1:我们确实没有Hadoop这类大数据产品,我们的数据类产品主要做的是数据治理。和容器的结合,主要是做元数据的管理。还有就是我们的容器云基于k8s,k8s现在的有状态业务能力还比较弱,还要等待一两个版本进行完善。

 

Q2:WAS是很重的J2EE容器,那么容器化必然会考虑他的启动时长限制,一般用这类云的都是并发较高的互联网应用,关于动态扩展到实际对外提供服务的时间间隔区你们怎么控制的呢?另外关于底层类加载的优化一般通过什么手段达到目标呢?

A2:容器化后我们这边基本上都是嵌入式应用服务器了,当然,IBM那边肯定会推荐WebSphere的Liberty版本。但是即使是嵌入式应用服务器,启动时间也还是有点慢,前段时间我正在做这个优化,应用稍微大一点,最快也要个十几秒,确实离理想状态还有点远。类加载这块,我感觉能做的优化不多,懒加载肯定不行。降低优化级别的话,虽然启动快了,但是运行时性能会下降。

原文发布时间为:2016-12-20

时间: 2024-10-02 17:07:36

应用容器云:接过Java EE的枪的相关文章

微服务:Java EE的掘墓人

在Java问世之初,包括IBM.BEA.Oracle在内的一些巨头公司看到了Java作为一门杰出的Web编程语言可能给他们带来的巨大商机.那么如何通过一门编程语言来赚钱呢?答案就是使用这门语言构建复杂无比的服务器,让那些大公司支付一大笔费用来购买这些服务器.于是紧接着就出现了Java EE规范.JSR规范,以及WebLogic.WebSphere等服务器中间件. 在这些服务器上面部署了大型的程序包,它们运行缓慢,消耗大量的内存.基于这些容器的开发和调试对开发人员来说简直就是噩梦,作为对他们的补偿

甲骨文宣布因 '主要增强功能'延迟发布Java EE 8

甲骨文(Oracle)公开承认不得不再一次延迟Java  8企业版的发布.新版Java企业版(Java EE)将于2017 年底上架,比原定计划推迟了至少六个月.甲骨文上一次调整发布日期是今年6月,其时的计划发布日期是明年"上半年". 甲骨文Java EE 和应用程序服务器开发副总裁Anil Gaur在美国加州旧金山的召开的甲骨文JavaOne大会上公布了新日期. Gaur承诺Java EE 9 将于Java  EE 8发布后的一年后发布,即是说 2018年年底. Gaur 表示,Ja

Oracle在JavaOne上宣布Java EE 8将会延期至2017年底

经过数周的猜测之后,Oracle负责Java EE和WebLogic Server的副总裁Anil Gaur在JavaOne上公布了Oracle针对Java EE的路线图.他们的规划包括在2017年底发布Java EE 8,这个版本会具备基本的微服务和云功能,并且计划在此一年后发布Java EE 9,这个版本将会包含进一步的特性. 这与一个月前他在JCP执行委员会上的表述一致,也与对Oracle产品开发总裁Thomas Kurian的采访相符,Gaur在JavaOne上的Java主旨演讲涉及到三

调查显示,Java EE 用户需要更多的 REST

自世纪初以来,Java企业版(Java EE)一直是许多企业以 Web 为中心,面向服务,支持云计算组件的核心.不过最近有许多用户,包括它的死忠粉也一直在问,它的框架是否已经过时,并正在被更轻量.更敏捷和更简单的设置,如容器.云服务或 API 取代. 为了回应 Java EE 现在面临的问题,Oracle 的 Java EE 开发团队在社区对 Java EE 的用户进行了一次调查,以了解该框架后续该为其企业基础服务的方向.共有1693个 Java EE 社区成员参与了调查,这些发现将有助于确定哪

Java EE 即将死去,毫无疑问!

在Java问世之初,包括IBM.BEA.Oracle在内的一些巨头公司看到了Java作为一门杰出的Web编程语言可能给他们带来的巨大商机.那么如何通过一门编程语言来赚钱呢?答案就是使用这门语言构建复杂无比的服务器,让那些大公司支付一大笔费用来购买这些服务器.于是紧接着就出现了Java EE规范.JSR规范,以及WebLogic.WebSphere等服务器中间件. 在这些服务器上面部署了大型的程序包,它们运行缓慢,消耗大量的内存.基于这些容器的开发和调试对开发人员来说简直就是噩梦,作为对他们的补偿

在Java EE环境下使用Kodo EJB

Kodo EJB是一个支持对象/关系映射的框架,根据EJB3规范的要求,Kodo EJB除了支持在普通Java应用中提供轻量级的持久层框架之外,也支持在JAVA EE容器中使用满足重量级企业应用的需求,充分利用JAVA EE容器中提供的优越特性如容器管理事务.远程(Remote)访问. 基于Kodo EJB开发的应用支持使用EJB或者JCA标准接入到JAVA EE环境中: JCA Kodo EJB支持JCA1.0标准,因此基于Kodo EJB开发的应用可以和其他JCA资源一样轻松的发布到JAVA

JPA --Java EE 5.0 ORM 规范

JPA概述 JPA(Java Persistence API)作为Java EE 5.0平台标准的ORM规范,将得到所有Java EE服务器的支持.Sun这次吸取了之前EJB规范惨痛失败的经历,在充分吸收现有ORM框架的基础上,得到了一个易于使用.伸缩性强的ORM规范.从目前的开发社区的反应上看,JPA受到了极大的支持和赞扬,JPA作为ORM领域标准化整合者的目标应该不难实现. JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中,图 1很好地描述

使用SIP Servlet为Java EE添加语音功能

会话发起协议(Session Initiation Protocol,SIP)是一种信号传输协议,用于建立.修改和终止两个端点之间的会话.SIP 可用于建立 两方呼叫.多方呼叫,或者甚至 Internet 呼叫.多媒体呼叫和多媒体分发的多播会话.JSR 116:SIP Servlet API 是一个服务器端接口,描 述了针对 SIP 组件及服务的容器.SIP servlet 是在 SIP 容器中运行的 servlet,与 HTTP Servlet 类似,但提供了对 SIP 协议的支持. SIP

主流Java EE应用服务器横向对比分析

在开源Java应用服务器领域,像JBoss.Tomcat及Apache的Geronimo,他们不仅仅是商 业领域的领跑者,同时是技术领域的先行者.当然,所有的Java EE应用服务器的实现不 尽相同,但其很多方面具有一定程度的可比性.本文对JBoss4.2.Geronimo 2及Tomcat 6 三种开源的Java EE应用服务器,就他们的特性.部署及性能等方面进行一一比较. 一.前言 当企业级的Java应用程序需要真正的应用部署时,Java EE应用服务器是必不可少的工 具.研究表明,除了商业