设为首页 收藏本站
查看: 660|回复: 0

[经验分享] Tomcat 7优化前及优化后的性能对比

[复制链接]

尚未签到

发表于 2017-2-4 10:11:32 | 显示全部楼层 |阅读模式
Tomcat 7优化前及优化后的性能对比
发表于19天前(2014-06-04 10:38)   阅读(10854) | 评论(106) 670人收藏此文章, 我要收藏
赞109
摘要 Tomcat 7在我们日常开发、测试、生产环境都会使用到,但对于大部分开发人员来说,对其性能还是没有多大了解。本文就对它做一次性能测试,对比优化前后的性能区别。

目录[-]
一、运行环境
二、未调优前
三、优化后
四、总结
一、运行环境

CPU: Intel(R) Pentium(R) P6200@2.13GHz  ;

内存:4G,装的是32位win7,只认出3G,没有花时间去整ramdisk之类的东西;

操作系统:win7 32位;

JDK:1.7.0_55

Tomcat:7.0.53

大家不要笑,公司电脑,就给配这样的,慢的要死,悲剧!

下面所有测试都是基于1000个请求做的,且都是访问Tomcat默认的ROOT首页

二、未调优前

并发用户数从10-1000挨个测试,测试结果如下:









从上面的测试结果来看,除去200用户并发的时候(这时候可能在做GC),吞吐率和请求处理时间都比较稳定,但请求等待时间到后面就飕飕的往上涨了。经观察,CPU负载均在80%以下。



三、优化后

优化主要是对Tomcat做的,主要有两方面:

1、在bin/catalina.bat文件中加入下面参数,对JVM进行优化,至于这一大驼参数的作用及说明,大家到网上找找,应该有很多的,如:http://www.mzone.cc/article/321.html

01
set JAVA_OPTS=
02
-server
03
-Xms1000M
04
-Xmx1000M   #-Xms与-Xmx设成一样的值,避免JVM因为频繁的GC导致性能大起大落
05
-Xss512k
06
-XX:+AggressiveOpts
07
-XX:+UseBiasedLocking
08
-XX:PermSize=64M
09
-XX:MaxPermSize=300M
10
-XX:+DisableExplicitGC
11
-XX:MaxTenuringThreshold=31
12
-XX:+UseConcMarkSweepGC
13
-XX:+UseParNewGC  
14
-XX:+CMSParallelRemarkEnabled
15
-XX:+UseCMSCompactAtFullCollection
16
-XX:LargePageSizeInBytes=128m  
17
-XX:+UseFastAccessorMethods
18
-XX:+UseCMSInitiatingOccupancyOnly
19
-Djava.awt.headless=true

上述这样的配置,基本上可以达到:

系统响应时间增快

JVM回收速度增快同时又不影响系统的响应率

JVM内存最大化利用

线程阻塞情况最小化



2、Tomcat连接参数的优化,主要是针对吞吐量做优化:

修改conf/server.xml文件,把原来

1
<Connector port="8080" protocol="HTTP/1.1" />
改成下面的内容

01
  <Connector port="8080" protocol="HTTP/1.1"
02
           URIEncoding="UTF-8"  
03
           minSpareThreads="25"
04
           maxSpareThreads="75"
05
           enableLookups="false"
06
           disableUploadTimeout="true"
07
           connectionTimeout="20000"
08
           acceptCount="300"   
09
           maxThreads="300"
10
           maxProcessors="1000"
11
           minProcessors="5"
12
           useURIValidationHack="false"
13
           compression="on"
14
           compressionMinSize="2048"
15
           compressableMimeType="text/html,text/xml,text/javascript,text/css,text/plain"
16
           redirectPort="8443"/>

然后我们再来看看10-1000个并发用户发起1000个请求时所表现的性能是怎么的。





大家可以看到,经过优化后,吞吐率已经能达到平均1800-1900左右,而处理时间基本能稳定在0.6ms,而等待时间最高不到600ms。

四、总结

通过两个结果对比可以看出,吞吐率及服务器处理时间有很大的改观,当然在我这破机器上也就这样一个效果了,再优化估计也不会“飞”起来,有兴趣的朋友可以找台牛B点的机器自己试试。试完了希望告诉我结果,让我也高兴一下。



PS:这是我写的第一篇技术文章,大家将就着看,以后多练练,争取写出更有水平的文字来。



我一直在看大家的评论,很多人说我这1000并发太少了,其实我真不知道我这样配置的机子的极限能达到多少,不知道哪位有经验的同志能告诉一声?

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-337272-1-1.html 上篇帖子: Hibernate使用Tomcat连接池连接数据库 下篇帖子: tomcat 下SSL客户端验证相关配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表