Struts2、SpringMVC、Servlet(Jsp)性能对比 测试 。

Servlet的性能应该是最好的,可以做为参考基准,其它测试都要向它看齐,参照它。

做为一个程序员,对于各个框架的性能要有一个基本的认知,便于选型时做出正确的决策。

在测试中发现了什么也不要大喊大叫,因为这些都是Java程序员的基础知识。 人人都要了解。

---------------------------------------------------------------------------------------

建议先阅读《你想建设一个能承受500万PV/每天的网站吗? 》一文,了解一些测试的基本概念。在测试开始前就有一个性能好与坏的标准。再用这个标准来检验你程序。

--------------------------------------------------------------------------------------- 
测试环境说明: 
服务器: 4G内存,至强3.0 (4核超线程)CPU,windows 2003 
测试机:笔记本 2G内存,p8600 双核CPU,windows XP 
网络:100Mb局域网 
测试软件: 
Jmeter 2.3.4    分配了512M内存 
tomcat 6  默认内存大小

--------------------------------------------------------------------------------------- 
测试配置如下图: 其实jmeter还是很弱的,我打开"集合点(synchronizing Timer)","察看结果树","用表格查看结果"中的任何一个都会导致测试结果中的性能下降和小部分请求的响应出错(可能是线程数太多了),所以禁用了。只启用了cookie管理器。

--------------------------------------------------------------------------------------- 
Tomcat6.0 配置文件的说明 ,做测试之前是要整清楚的。 
默认的Server.xml中如下

  1. <Connector port="8080" maxHttpHeaderSize="8192"
  2. maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
  3. enableLookups="false" redirectPort="8443" acceptCount="100"
  4. connectionTimeout="20000" disableUploadTimeout="true" />

enableLookups 
是否允许DNS查询,当web应用程序要通过域名服务器查找机器名转换为IP地址时。会使用DNS查询,需要占用网络,延长较长 
maxThreads 
Tomcat可创建的最大的线程数,每一个请求须要一个线程来处理,原来的150太小了,我们测试时并发会超过他的。 
acceptCount 
指定当所有可以使用的处理请求的线程数都被使用时,可以放到处理队列中的请求数,就是被排队的请求数,超过这个数的请求将拒绝连接。 
connnectionTimeout 
网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为20000毫秒。 
minSpareThreads 
Tomcat初始化时创建的线程数 
maxSpareThreads 
一旦创建的线程中空闲线程超过这个值,Tomcat就会关闭不再需要的socket线程。

注意:maxThreads 设置为500 ,也就是Tomcat最多同时使用500个线程处理500个并发(服务器CPU不错,500没问题),不要发生 排队等待的情况以免影响测试成绩, 为下面的压力测试做好准备。

---------------------------------测试开始了------------------------------------------- 
测试时服务器CPU使用率 10% 
测试时测试机CPU使用率 100%(测试机不行啊,主要是 Jmeter的性能一般,又吃内存,测试机p8600 双核CPU还是很强的 ) 
每次测试CPU都这样,就统一写这里了。

测试1:JSP页面--2213个请求/秒 
100并发,循环100次,共10000个请求,请求一个大小3.34KB的jsp页面。

测试2:JSP页面--1889个请求/秒 
100并发,循环100次,共10000个请求,请求一个servlet总控制器,验证权限后(很简单),new一个Action,再转发到一个大小3.34KB的jsp页面。

测试3:HTML页面--2607个请求/秒 
100并发,循环100次,共10000个请求,请求一个3.2KB的html页面。

测试4: HTML页面-- 833个请求/秒 
100并发,循环100次,共10000个请求,请求一个13.4KB的html页面。与上面比是只是文件大了一些,把网卡跑满了 ,网卡成为了性能瓶颈,RPS降了不少!!

测试5: Spring MVC   2012个请求/秒 
100并发,循环100次,共10000个请求,请求一个spring3 MVC的action,再转发到一个0.8K的JSP,其内容是简单的html

测试6: Spring MVC    1800-1924个请求/秒 
100并发,循环100次,共10000个请求,请求一个spring3 MVC的action,两个参数类型转换为int、Date,再new 一个List,再转发到一个1.3K的JSP,用JSTL标签显示List中的内容。

JSTL标签内容是如下,看来JSTL标签性能还是不错的。

  1. <c:if test="${empty list}">
  2. <tr>
  3. <td align="center">无记录!</td>
  4. </tr>
  5. </c:if>
  6. <c:if test="${not empty list}">
  7. <tr>
  8. <th>从 1 开始的迭代计数</th>
  9. <th>从 0 开始的迭代计数</th>
  10. <th>产品名称</th>
  11. </tr>
  12. <c:forEach items="${list}" var="item" varStatus="s">
  13. <tr bgcolor=${s.index%2==0?"#E2E2E2":""}>
  14. <td align="center">${s.count}&nbsp;</td>
  15. <td align="center">${s.index}&nbsp;</td>
  16. <td align="center">${item}&nbsp;</td>
  17. </tr>
  18. </c:forEach>
  19. </c:if>

测试7: 访问一张图片(srping方式一)   1997个请求/秒 
100并发,循环100次,共10000个请求. 因为我使用了spring3 MVC,拦截/,所以图片不能访问,所以添加了:

  1. <servlet-mapping>
  2. <servlet-name>default</servlet-name>
  3. <url-pattern>*.jpg</url-pattern>
  4. </servlet-mapping>

走默认的servlet,来访问2.5K的图片

测试8: 访问一张图片 (srping方式二)    1967个请求/秒 
100并发,循环100次,共10000个请求,因为我使用了spring3 MVC,拦截/,所以图片不能访问,所以添加了: 
<mvc:resources mapping="/images/**" location="/images/" cache-period="31556926"/> 
来访问2.5K的图片,会走spring的可匹配的一个拦截器。

测试9:Struts2  使用官方提供的示例程序 (使用了Struts2标签 )  几十个请求/秒 
100并发,循环1次,没有循环100次,因为strtus2在这次测试中响应太慢了,我等不起了,所以单个url的测试样本从10000降到了100.一共11个url,共1100个样本。 
"spring" 使用的就是前面“测试5”的URL,放在这里是为了与strtus2对比的。 
"html"   使用的就是前面“测试3”的URL,放在这里是为了与strtus2对比的。 
"struts2-1" 使用的是官方自带的示例项目,名称是struts2-blank-2.1.8.1.war 
"struts2-2" 使用的是官方自带的示例项目,名称是struts2-showcase-2.1.8.1.war,我在其中随便选了一个action来做测试 
"struts2-3" 同上 
"struts2-4" 同上 
"struts2-5" 同上 
"struts2-6" 同上 
"struts2-7" 同上 
"struts2-8" 同上 
"struts2-9" 同上 
未对Struts2做优化,使用的都是官方带的示例,Struts2的测试结果不理想,放在这里做一个参考。“struts2-1”是struts2中测试成绩是本次最高的,但也不十分理想。

测试10:Struts2   官方提供的 示例程序 (使用Struts2标签--s:property)   1192个请求/秒 
上一个测试结果糟糕的太离谱了,第二天,想了想又开始重新测试,使用的还是struts2官方提供的struts2-blank-2.1.8.1.war示例。

访问下面的action:    http://192.168.0.5/struts2/example/HelloWorld.action   ,action内容很简单就是转发到一个JSP。

下图是使用官方示例中默认的action,我没有修改,结果如下图

这里要说一说转发到的jsp中的内容,其中有struts2标签,如下:

  1. <s:property value="message"/>
  2. <s:url id="url" action="HelloWorld">
  3. <s:param name="request_locale">en</s:param>
  4. </s:url>
  5. <s:a href="%{url}">English</s:a>

测试11:Struts2   官方提供的 示例程序 (不使用Struts2标签)   1976个请求/秒--优秀啊

我把“测试10”中的jsp文件内容改了,删除了所有的struts2标签,只输出一行文本,测试结果如下图:

天啊,性能超出我的想像,性能太好了,达到了我的要求。看来一定是struts2标签拖了后腿。

测试12:Struts2   官方提供的 示例程序 (使用Struts2标签--s:form)   426个请求/秒 
为了让现象复现,我把 “测试10”中 jsp又改了,jsp中换用了其它的struts2标签 ,测试结果如下图:

使用的标签是:

  1. <s:form action="Login">
  2. <s:textfield key="username"/>
  3. <s:password key="password" />
  4. <s:submit/>
  5. </s:form>

=====================================================

结论:

struts2框架性能很好, 但struts2的标签性能太差了。 要避免使用 struts2标签。 
Struts2 由于采用了 值栈、OGNL表达式、struts2标签库等,会导致性能下降,很严重的下降。如果避免或减少使用这些,性能还是很好的。 
Struts2的 多层拦截器、 多实例action性能都很好,并不是 导致性能问题的原因。

注:以上测试都没有数据库,也没有复杂业务,action和jsp中内容很简单,目的就是测试MVC部分的性能。

--------------------------------------------------------------------------------------- 
其它测试文章: 
http://zhaoshg.iteye.com/blog/356231 
http://www.iteye.com/topic/679543

MVC框架性能比较 
http://wenku.baidu.com/view/148d7e34eefdc8d376ee32ac.html

spring3mvc与struts2比较 
http://www.iteye.com/topic/646240

---------------------------------------------------------------------------------------

附:几种标签和框架组合解析数据时候的 性能测试对比 

一、 数据
数据通过查询日志表得到数据,共 1302 条数据,将查询出的数据放入一个静态 List 中,保证每次请求的数据相同。 
测试页面的元素相同,只是在取数据方式上不同。

二、 测试目标 
1、 在 JSP 页面使用 struts2 标签的性能; 
2、 在 JSP 页面使用 JSTL 标签的性能; 
3、 在 Freemarker 页面使用 struts2 标签的性能; 
4、 在 Freemarker 页面使用 JSTL 标签的性能; 
5、 在 Freemarker 页面使用其本身的数据加载方式的性能。

三、 加载耗时对比 
时间: ms           注:每一次对比都是在同一时间段按同一顺序依次执行下列几种方式

struts2

JSTL ( C )

Freemarker-struts2

Freemarker-C

Freemarker

第一次

306

58

1618

41

第二次

202

52

1643

39

第三次

211

58

2047

36

第四次

196

49

1621

28

第五次

218

52

1607

40

第六次

303

331

1857

45

第七次

210

50

1671

33

第八次

311

51

1699

47

第九次

462

55

2180

37

第十次

218

46

1721

42

平均值

263.7

80.2

1766.4

38.8

去掉最高和最低

223.75

53.125

1547.125

39.125

Struts2、SpringMVC、Servlet(Jsp)性能对比 测试的更多相关文章

  1. [原] KVM 环境下MySQL性能对比

    KVM 环境下MySQL性能对比 标签(空格分隔): Cloud2.0 [TOC] 测试目的 对比MySQL在物理机和KVM环境下性能情况 压测标准 压测遵循单一变量原则,所有的对比都是只改变一个变量 ...

  2. BeetleX和Asp.net Core之webapi基础性能对比

    本文主要针对BeetleX和Asp.net Core在基础WebApi功能性能对比 测试环境描述 硬件配置:E1230V2 16G内存 10Gb带宽 操作系统:Windows server 2008 ...

  3. MyISAM与InnoDB两者之间区别与选择,详细总结,性能对比

    1.MyISAM:默认表类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Access Method (有索引的顺序访问方法) 的缩写,它是存储记录和文件的标准方法.不 ...

  4. MYSQL 中 MyISAM与InnoDB两者之间区别与选择,详细总结,性能对比

    1.MyISAM:默认表类型,它是基于传统的ISAM类型,ISAM是Indexed Sequential Access Method (有索引的顺序访问方法) 的缩写,它是存储记录和文件的标准方法.不 ...

  5. struts2,servlet和springmvc的单例多例问题

    struts2,servlet和springmvc的单例多例问题 原创 2017年06月12日 09:59:21 标签: struts2 / servlet / springmvc / 单例 / 多例 ...

  6. 文件上传(Servlet/Struts2/SpringMVC)

    文件下载(Servlet/Struts2)的链接:http://www.cnblogs.com/ghq120/p/8328093.html 文件上传 Servlet实现 要实现文件上传的功能,必须在f ...

  7. springMVC: java.lang.ClassNotFoundException: javax.servlet.jsp.jstl.core.Config

    springMVC开发web的时候,报错:java.lang.ClassNotFoundException: javax.servlet.jsp.jstl.core.Config 原因:未引入jstl ...

  8. [springMVC]javax.servlet.jsp.JspTagException: Neither BindingResult nor plain target object for bean

    问题描述: 页面使用标签<form:form>进行提交时,出现[springMVC]javax.servlet.jsp.JspTagException: Neither BindingRe ...

  9. 两款JSON类库Jackson与JSON-lib的性能对比(新增第三款测试)

    本篇文章主要介绍了"两款JSON类库Jackson与JSON-lib的性能对比(新增第三款测试)",主要涉及到两款JSON类库Jackson与JSON-lib的性能对比(新增第三款 ...

随机推荐

  1. nodejs API(二)

    官网所在位置:https://nodejs.org/dist/latest-v6.x/docs/api/querystring.html querystring.escape(str) 转义   qu ...

  2. oracle 基本函数小例子--查询身高段分数段

    select * from student order by id drop table student select * from oracletest create table student( ...

  3. php 共享内存学习(APC扩展)

    问题:希望可以在进程间共享变量,为共享数据提供快速访问 解决方案:使用APC扩展的数据存储功能 (cli模式下没有作用) //获取原来的值 $population = apc_fetch('popul ...

  4. Java 设计模式系列(二三)访问者模式(Vistor)

    Java 设计模式系列(二三)访问者模式(Vistor) 访问者模式是对象的行为模式.访问者模式的目的是封装一些施加于某种数据结构元素之上的操作.一旦这些操作需要修改的话,接受这个操作的数据结构则可以 ...

  5. MDK5使用技巧

    1.文本美化 修改 修改字体以及颜色如下: 修改用户自定义的关键字,如下: 代码编辑技巧 1.TAB键的妙用 使用TAB键可以整体向右移动相应位,使用SHIFT+TAB键整体左移相应位. 2.快速定位 ...

  6. word生成包含echarts图形使用phantomjs,支持word2003,2007

    代码具体地址在我的github上 :https://github.com/HaoTwoDonkey/QuickOutPutWord 写得不好,欢迎提出问题 下面说几个phantomjs使用过程中遇到的 ...

  7. Problem of Uninstall Cloudera: Cannot Add Hdfs and Reported Cannot Find CDH's bigtop-detect-javahome

    1. Problem We wrote a shell script to uninstall Cloudera Manager(CM) that run in a cluster with 3 li ...

  8. AngularJS-$scope类

    一.$scope的作用 用来在controller和view中进行数据.事件的传递 二.$scope和$rootscope的区别 1.$rootscope根作用域 2.$rootscope可以实现多个 ...

  9. javadoc tags

    Where Tags Can Be Used The following sections describe where the tags can be used. Note that these t ...

  10. 看图说说JVM新生代垃圾收集器