浅析JavaEE容器重部署时间的调查数据

开发 后端
在这里我们将就JavaEE容器重部署时间的调查数据进行分析,希望对大家了解不同工具的性能有所帮助。

以下是关于JavaEE容器重部署时间的调查,通过调查结果显示,能得出一些结论,并使广大开发人员从中获益。

近日,Jevgeni Kabanov公布了一份几个月前做的关于JavaEE开发、容器和部署时间的调查结果。结果显示有超过1100人参加了这次问卷调查。这里是下载版的问卷结果。而下面是Jevgeni作出的针对每个问题答案分析的摘要。

问卷的第一个问题是:“你在目前参与的最大型项目中使用的是什么容器?”

图表1:哪个容器是最常使用的?

哪个容器是最常使用的?

这里没有包括那些得分不到10分的容器。毫无悬念,Apache的Tomcat占据了头把交椅,而JBoss紧随其后。开源的服务器占到了70%的比例。虽然不能把这样的比例直接等同于容器们的市场份额,但这样的结果跟SD Time作出的研究结果有异曲同工之妙,在他们的调查中允许人们选择多个容器。

第二个问题是:“重启你的容器并重新部署应用要花费多少时间?”

图表2: “重启你的容器并重新部署应用要花费多少时间”(横轴是分钟)

重启你的容器并重新部署应用要花费多少时间?

这样,计算出平均时间在2.5分钟左右,这跟事先评估的大概1分钟相去甚远。

第三个问题:“编码一个小时,你会重新部署几次?”

图表 3:“编码一个小时,你会重新部署几次?”

编码一个小时,你会重新部署几次?

对于那些回答“我不需要重新部署”的人,我们询问了他们是如何做到的,答案有以下这些:

“我不负责重新部署”

“我们在嵌入式jetty&activemq&atomikos以debug模式开发,而不是OracleAS上。这样,我们虽然需要重新部署并重启jetty,但不需要对OAS也这么做”

“我还处在项目的早期阶段,大部分时间都花在了编码和测试,而不是重新部署上——通常每个小时我会重新部署3-4次”

“我们使用JavaRebel,而它真是太棒了!”

接着,我们做了一下数据处理。用一个数字代表次数间隔(比如3.5次代表3-4次),并把每小时的部署次数与一次重新部署所费时间相乘(基本上就是图2和图3相乘),这样就得出了在开发过程中每小时会花费的重新部署时间:

图表4:“ Java开发者在一个小时编码过程中,花费多长时间来重新部署(原始数据)?”

花费多长时间来重新部署

平均时间是12分半,占到了整个开发时间的20%还多点。然而,标准差超过14,这意味着真实的比例变化很大。我们想要显示出更加精确的数据,在分析过参与调查的人们在每个答案上的选择所产生的比例数据后,我们得到了更新后的图表:

图表5:“ Java开发者在一个小时编码过程中,花费多长时间来重新部署?(更加精确的数据)”

这样,平均时间就是10.5分钟,标准差是8,这样的数据更令人信服。这个时间占据了全部开发时间的17.5%,这远比我们预期的要高。这些干净的数据也将用作接下来的分析。

接着,我们基于每个容器进行了数据分析。下面是我们所发现的:

图表6:每个容器要花费多少时间来重新部署?

每个容器要花费多少时间来重新部署?

可以看到,Jetty最快仅需要5.8分钟,而IBM的WebSphere排在了末尾,时间几乎是Jetty的两倍还多。但需要注意的是,虽然Jetty启动时间要比WebSphere要看,但最大的不同很可能是因为部署的应用规模和其中使用到的技术。

接下来,我们拥有了几乎一模一样的图表,但数字显示的是开发时间的一个比例。

图表7:每个容器中,花在重新部署上的开发时间比例是多大?

花在重新部署上的开发时间比例是多大?

下面这张图,显示了按40小时每周的时间算,每年要消耗在重新部署上的周数对比。

图表8:每年有多少个40小时周被花费在了重新部署阶段上?

每年有多少个40小时周被花费在了重新部署阶段上?

这个数据的平均值是每年5个工作周多一点,但标准差4使得3-7的范围更加可信。

最后一张图表显示了每个容器上所费重新部署时间更加详尽的比例。我们期望这样能显示出使用不同容易的项目规模,从而能让读者大概弄清楚自己的项目会花费多少时间在重新部署上。

图表9:: Java EE容器市场渗透率

Java EE容器市场渗透率

我们会这样诠释这幅图表:

Jetty只会用在重新部署迅速的项目上。这点毫无疑问,因为Jetty不支持重新部署,只是有极快的重新启动时间。

Apache Tomcat和GlassFish可以用在相同类型的项目上。两者都是全功能且轻量级的容器。

JBoss、Oracle Weblogic和IBM WebSphere争夺同样的市场定位和份额。它们的项目一般都是大而复杂。

【编辑推荐】

  1. 走近JavaEE5与Glassfish应用服务器
  2. Java设计模式之装饰模式
  3. Apache对JavaEE 6说“不”
  4. J2EE设计模式之Template
  5. J2EE常用的设计模式
责任编辑:彭凡 来源: ITPUB BLOG
相关推荐

2020-07-01 15:16:45

无根容器云安全云计算

2024-01-15 16:43:29

Docker容器

2009-07-06 09:45:51

Java EE容器重新部署

2009-07-14 10:47:47

MyEclipse J

2009-09-28 09:07:23

2023-05-30 14:56:18

Docker开发容器

2023-08-31 12:07:08

2019-12-20 07:28:45

Docker容器安全云计算

2023-08-21 15:28:36

云原生Kubernetes

2010-08-10 10:44:22

Flex开发

2020-06-04 15:17:22

安全物联网漏洞

2010-09-30 16:47:21

2023-01-03 09:10:21

2015-04-09 09:56:54

软件定义网络数据中心网络SDN

2013-07-18 14:14:06

2023-08-06 23:26:39

2010-07-21 09:21:10

云计算

2018-02-02 13:58:59

数据存储

2013-05-15 11:05:46

LTEPTN网络部署

2011-03-30 09:28:34

MySQL数据碎片
点赞
收藏

51CTO技术栈公众号