`

Tomcat 7优化前及优化后的性能对比

 
阅读更多
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并发太少了,其实我真不知道我这样配置的机子的极限能达到多少,不知道哪位有经验的同志能告诉一声?

分享到:
评论

相关推荐

    redis集群jvm调优实战MySQL5.6性能优化&Tomcat7优化.rar

    本资料集围绕四个核心主题展开:Redis集群、JVM调优、MySQL 5.6性能优化和Tomcat 7的优化,旨在帮助开发者和运维人员更好地理解和实践这些关键领域的优化策略。 首先,Redis是一个高性能的键值存储系统,常用于缓存...

    Tomcat性能优化及JVM内存工作原理

    Tomcat性能优化及JVM内存工作原理 Tomcat性能优化是指通过调整Tomcat服务器的配置和JVM的参数,以提高Tomcat服务器的性能和响应速度。Tomcat性能优化主要包括代码层优化、JVM内存优化和应用配置优化三方面。 代码...

    Tomcat7及Tomcat8

    Tomcat 8是继Tomcat 7之后的版本,它进一步提升了性能和功能,主要支持Java EE 7规范,包括以下亮点: 1. **Servlet 3.1**:增加了HTTP/2协议的支持,提供更快的数据传输速度和更低的延迟,同时也支持WebSockets。 ...

    Tomcat7性能优化.pdf

    #### 三、Tomcat优化配置 ##### 3.1 配置Tomcat管理员账户 - 在`conf/tomcat-users.xml`文件中添加管理员角色和用户信息,确保服务器的安全管理。 - 角色配置示例: ```xml ``` - 用户配置示例: ```...

    Apache Tomcat8优化说明

    本篇将详细介绍 Tomcat 8 的优化策略及相关配置参数。 #### 二、HTTP 连接器概述 HTTP 连接器是 Tomcat 8 中的核心组件之一,负责监听 TCP 端口并处理来自客户端的 HTTP 请求。通过合理的配置,可以显著提升 Tomcat...

    Tomcat性能优化配置方案

    1.操作系统调优; 2.Java虚拟机调优; 3.Apache集成Tomcat; 4.【适用场景】 大量使用静态页面的应用系统; 5.【适用场景】 并发用户量及在线使用用户数量比较高的系统

    TOMCAT优化

    ### TOMCAT优化详解 #### 一、引言 随着互联网技术的发展及企业级应用的不断扩展,服务器性能优化成为提高用户体验、确保业务稳定的关键因素之一。Apache Tomcat作为一款广泛使用的开源Servlet容器,其性能直接...

    tomcat7和8

    Apache Tomcat是一款开源的Java Servlet容器,用于部署和运行Java Web应用程序。它是基于Sun Microsystems的Java Servlet和...在实际操作中,确保正确安装和配置Tomcat,以及定期更新以获取最新的安全补丁和性能优化。

    tomcat8和tomcat7

    Tomcat7和Tomcat8是两个不同版本的Tomcat,它们在功能、性能和安全性上有所区别。 **Tomcat7** Tomcat7是2011年发布的,支持Java EE 6规范,包括Servlet 3.0、JSP 2.2和EL 2.2等。以下是一些关键特点: 1. **...

    Tomcat解析与性能优化.pdf

    ### Tomcat解析与性能优化知识点概述 #### 一、Tomcat基本构成与文件结构 **1. 文件构成** - **1.1 server/shared/common目录** - **Java类库存放位置**:`/server/lib`、`/shared/lib` 和 `/common/lib` 三个...

    tomcat6和tomcat7

    本资源提供了Tomcat6和Tomcat7两个不同版本,它们在功能、性能以及兼容性方面有所差异,适合不同需求的开发者使用。 **Tomcat6** Tomcat6是Apache Tomcat服务器的一个早期版本,发布时间在2005年。这个版本主要支持...

    tomcat7集中了很多的技术,是对技术的综合

    标签“tomcat7比较好”暗示了Tomcat 7在用户中的口碑和实用性。相比早期版本,Tomcat 7在易用性、稳定性和性能上都有所增强,而且与开源社区的其他工具和框架兼容性良好,比如Spring、Hibernate等。 综上所述,...

    Tomcat7服务器

    6. **性能优化**:Tomcat7可以通过调整线程池大小、开启NIO(非阻塞I/O)模式、启用连接器优化等方式提高性能。同时,合理设置JVM参数也是提升性能的关键。 7. **热更新**:在开发阶段,Tomcat7支持热更新,只需...

    webServer tomcat5 / tomcat6 / tomcat7 / tomcat8

    标题中的"webServer tomcat5 / tomcat6 / tomcat7 / tomcat8"涉及到的是Apache Tomcat服务器的不同版本。Tomcat是一款开源的Java Servlet容器,主要用于实现Java Web应用程序的运行环境。它支持Servlet和JSP标准,由...

    tomcat 版本6、7、8

    【标题】:“Tomcat版本6、7、8”的对比与演变 在Java Web开发领域,Apache Tomcat是一款广泛应用的开源Servlet容器,它实现了Java Servlet和JavaServer Pages(JSP)技术规范。Tomcat6、Tomcat7和Tomcat8是三个...

    tomcat 6 + tomcat 7

    3. **性能**:相比更早的版本,Tomcat 6在性能上有所提升,但相较于Tomcat 7及更高版本,可能会稍逊一筹。 4. **管理工具**:提供了一个基于Web的管理界面,可以用来管理应用部署、用户角色等。 5. **多线程模型**:...

    tomcat,oracle 参数优化

    文章不仅表达了对一位曾分享过“Tomcat如何承受1000个用户”知识的敬意,同时也是对原文的拓展,分享了在实际项目中应用这些知识后,成功提高了系统性能,包括处理更多并发用户和显著降低响应时间。 【标签】:...

    how tomcat works和jetty-src和tomcat7-src

    【标题】"how tomcat works和jetty-src和tomcat7-src" 提及了三个关键概念:Tomcat的工作原理、Jetty源代码以及Tomcat 7的源代码。这些是Java Web服务器领域的核心元素,主要涉及到如何处理HTTP请求、部署Web应用...

    Apache tomcat Group.rar

    Tomcat 7还优化了多线程模型,提高了可伸缩性。 这些不同版本的Tomcat在安全性、性能、易用性和功能上都有所差异。例如,Tomcat 7的管理和部署工具更加完善,使得应用程序的部署和管理更为便捷。同时,每个版本的...

Global site tag (gtag.js) - Google Analytics