一、前言

tomcat 服务器在JavaEE项目中使用率非常高,所以在生产环境对tomcat的优化也变得非常重要了,对于tomcat的优化,主要是从2个方面入手,一是tomcat本身的配置,另一个是tomcat所运行的Jvm虚拟机的调优

二、Tomcat配置优化

2.1 下载安装tomcat

案例中使用的Tomcat版本是 8.0+ 版本

下载安装:https://tomcat.apache.org/download-80.cgi

2.2 配置修改

cd apache-tomcat-8.5.47/conf/ 进入tomcat配置文件夹

vim tomcat-users.xml 需要配置文件,配置tomcat的管理用户

写入以下内容:

  <role rolename="manager"/>
<role rolename="manager-gui"/>
<role rolename="admin"/>
<role rolename="admin-gui"/>
<user username="tomcat" password="tomcat" roles="admin-gui,admin,manager-gui,manager"/> # 保存退出
# 如果是tomcat7,配置了tomcat用户就可以登录系统了,但是tomcat8中不行,还需要修改下面一个配置文件,否则访问不了,提示403 vim cd webapps/manager/META-INF/context.xml
<Context antiResourceLocking="false" privileged="true" >
<!-- <Valve className="org.apache.catalina.valves.RemoteAddrValve"
allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" /> -->
<Manager sessionAttributeValueClassNameFilter="java\.lang\.(?:Boolean|Integer|Long|Number|String)|org\.apache\.catalina\.filters\.CsrfPreventionFilter\$LruCache(?:\$1)?|java\.util\.(?:Linked)?HashMap"/>
</Context> # 保存退出即可
# 启动tomcat

2.33 启动访问

成功访问tomcat地址后,点击 首页中Server Status,输入用户名密码tomcat/tomcat



进入页面,我们需要关注的就是其中JVM的列表参数:

Eden Space:年轻代中的Eden区

Survivor Space:年轻代中的Survivor 区

Tenured Gen:老年代-养老区

其中Eden Space、Survivor Space、Tenured Gen属于堆内存,而下面的三个(Code Cache、Compressed Class Space、Metaspace)属于非堆内存

Code Cache:代码缓存区

Compressed Class Space:压缩类空间

Metaspace:元空间

三、Tomcat优化

3.1 禁用AJP连接

在服务状态页面可以看到,默认状态下回启用AJP连接,并且占用8011端口



什么是AJP呢?

AJP(Apache jServer Protocol)

AJP13协议是面向包的,WEB服务器和Servlet容器通过TCP连接来交互;为了节省SOCKET创建的昂贵代价,WEB服务器会尝试维护一个永久TCP容器,并且在多个请求赫尔响应周期过程会重用连接。

web客户端访问tomcat服务器上的JSP组件的两种方式,如下图所示:



我们一般是使用Nginx+tomcat的架构,所以用不着AJP协议,所以把AJP连接禁用。

修改conf下的Server.xml文件,将AJP服务禁用掉即可。

<Connector port="8011" protocol="AJP/1.3" redirectPort="8443" />



重启tomcat,查看效果:



可以看到AJP服务已经不存在了

3.2 执行器(线程池)

在tomcat中每一个用户请求都是一个线程,所以可以使用线程池提高性能

修改conf/server.xml文件:

 <!--将注释打开-->
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/> <!--
参数说明:
maxThreads:最大并发数,默认设置 200 ,一般建议在 500-1000,根据硬件设施和业务来判断
minSpareThreads:Tomcat 初始化时创建的线程数,默认设置 25
prestartminSpareThreads:在Tomcat初始化的时候就初始化 minSpareThreads 的参数值,如果不等于true ,minSpareThreads 的值就没啥效果了
maxQueueSize:最大的等待队列数,超过则拒绝请求
--> <!-- 在Connector中设置 executor 属性指向上面的执行器 -->
<Connector executor="tomcatThreadPool" port="8000" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />

保存退出,重启tomcat,查看效果

在页面中现实最大线程为 -1 ,这个是正常的,只是显示的问题,实际使用的指定的值

3.3 tomcat的三种运行模式

tomcat的运行模式有三种:

  • bio: 默认的模式,性能非常低下,没有经过任何优化处理和支持
  • nio: (new I/O),是Java SE 1.4及后续版本提供的一种新的 I/O操作方式(即java.nio包及其子包),java nio是一个基于缓冲区,并能提供非阻塞I/O操作的java API ,因此nio也被看成是 non-blocking I/O的缩写,它拥有比传统I/O操作(bio)更好的并发运行性能
  • apr: 安装起来最困难,不过在tomcat8中有最新的nio2,速度更快,建议使用nio2

设置nio2:

<Connector executor="tomcatThreadPool" port="8000" protocol="org.apache.coyote.http11.Http11Nio2Protocol"
connectionTimeout="20000"
redirectPort="8443" />

四、性能测试

4.1 使用Apache Jmeter 进行测试

Apache Jmeter 是开源的压力测试工具,我们借助此工具进行测试,将测试出tomcat的吞吐量等信息

4.1.1 下载安装

下载地址:http://jmeter.apache.org/download_jmeter.cgi



进入bin目录,找到meter.bat文件,双击打开即可启动。

注意:如果想要效果更好的体现最好使用一个项目demo进行测试

4.1.2 配置

第一步:保存测试用例



第二步:添加线程组,使用线程模拟用户的并发



1000个线程,每个线程循环10次,也就是tomcat会接收到10000个请求



第三步:添加http请求

这里我使用的是我的测试项目



第四步:添加请求监控

4.1.3 启动测试:

其中我们需要关注的就是 聚合报告 的数据

4.2 禁用AJP服务

可以看到,禁用AJP服务后,平均响应时间和吞吐量会有所提升,不过测试不一定准确,需要多测试几次才能看出来是否有提升。

4.3 设置线程池

通过审核制线程池,调整线程池相关的参数进行测试tomcat的性能

4.3.1 最大线程数为500,初始为50
  <Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/>

测试结果:

吞吐量为 5.8/秒,性能有所提升

是否是线程越多,速度越快呢,在实际测试中,并不是线程越多性能越高,单靠提升线程数量是不能一直得到性能提升的。

4.4 设置nio的运行模式

<Connector executor="tomcatThreadPool" port="8000" protocol="org.apache.coyote.http11.Http11Nio2Protocol"
connectionTimeout="20000"
redirectPort="8443" />

可以看到,平均响应时间有所缩短,吞吐量有所提升,所以从中可以看出,nio2的性能要高于Nio

4.5 调整JVM参数进行优化

4.5.1 设置并行垃圾回收器

修改 bin/catalina.sh

JAVA_OPTS="-XX:+UseParallelGC -XX:+UseParallelOldGC -Xms64m -Xmx512m -XX:+PrintGCDetails -XX:+PrintGCTimeStamps -XX:+PrintGCDateStamps -XX:+PrintHeapAtGC -Xloggc:../logs/gc.log"



可以看到,平均响应时间有所缩短,吞吐量有所提升

五、总结

今天的tomcat性能不知道大家看的怎么样,感兴趣的小伙伴可以点赞关注一波,有问题的小伙伴可以在下面留言,博主看到了会第一时间回复大家,谢谢,大家加油~

提高网站访问性能之Tomcat优化的更多相关文章

  1. 巧用linux服务器的/dev/shm/,如果合理使用,可以避开磁盘IO不给力,提高网站访问速度。

    巧用linux服务器的/dev/shm/ 巧用linux服务器的/dev/shm/,如果合理使用,可以避开磁盘IO不给力,提高网站访问速度. 首先让我们认识一下,什么是tmpfs和/dev/shm/? ...

  2. 提高磁盘访问性能 - NtfsDisableLastAccessUpdate

    这个技巧可以提高磁盘访问性能,不过仅适用于NTFS文件系统. 我们知道,当在磁盘管理应用程序中列出目录结构时──效果类似“资源管理器”.“文件管理 器”(Windows NT  3.xx/4.0下的称 ...

  3. 26种提高ASP.NET网站访问性能的优化方法 .

    1. 数据库访问性能优化 数据库的连接和关闭 访问数据库资源需要创建连接.打开连接和关闭连接几个操作.这些过程需要多次与数据库交换信息以通过身份验证,比较耗费服务器资源. ASP.NET中提供了连接池 ...

  4. 【Spring Boot&&Spring Cloud系列】提高数据库访问性能

    前言 使用关系型数据库的应用系统的性能瓶颈最终还是数据库.随着业务的迅速增长,数据量会不断增大,会逐渐暴露关系型数据库的弱点,性能会大幅度的降低 项目地址:https://github.com/And ...

  5. 性能测试之Tomcat优化

    1.Tomcat最大连接数等配置   Tomcat的server.xml中Context元素的以下参数都是什么意思? <Connector port="8080"maxThr ...

  6. 微软企业库5.0 学习之路——第四步、使用缓存提高网站的性能(EntLib Caching)

    首先先补习下企业库的Caching Application Block的相关知识: 1.四大缓存方式,在Caching Application Block中,主要提供以下四种保存缓存数据的途径,分别是 ...

  7. 【转】加快网站访问速度——Yslow极限优化

    Yslow是一套雅虎的网页评分系统,详细的列出了各项影响网页载入速度的参数,这里不做多说. 我之前就一直参考Yslow做博客优化,经过长时间的学习也算是有所收获,小博的YslowV2分数达到了94分( ...

  8. Google Font字体本地化使用提高网站访问速度

    Google Web font在国内经常不稳定,速度在国内延迟也很高,而引发网页打开速度慢. 一.常见的字体格式介绍 不同的浏览器对字体格式支持是不一致的,常见的如下: 1.TureTpe(.ttf) ...

  9. 在HTML5中如何提高网站前端性能

    1.    用web storage替换cookiesCookie最大的问题是每次都会跟在请求后面.在HTML5中,用sessionStorage和localStorage把用户数据直接在客户端,这样 ...

随机推荐

  1. spark机器学习从0到1主成分分析-PCA (八)

      PCA 一.概念 主成分分析(Principal Component Analysis)是指将多个变量通过线性变换以选出较少数重要变量的一种多元统计分析方法,又称为主成分分析.在实际应用场合中,为 ...

  2. spark机器学习从0到1支持向量机SVM(五)

        分类 分类旨在将项目分为不同类别. 最常见的分类类型是二元分类,其中有两类,通常分别为正数和负数. 如果有两个以上的类别,则称为多类分类. spark.mllib支持两种线性分类方法:线性支持 ...

  3. 永远不要使用双花括号初始化实例,否则就会OOM!

    生活中的尴尬无处不在,有时候你只是想简单的装一把,但某些"老同志"总是在不经意之间,给你无情的一脚,踹得你简直无法呼吸. 但谁让咱年轻呢?吃亏要趁早,前路会更好. 喝了这口温热的鸡 ...

  4. 本地项目链接github项目库

    本地有个用了好久用来测试功能的项目,今天用来测试链接github项目库,做一下记录   目标:把本地的项目和github上的项目连接起来 工具:sourceTree   sourceTree提供了gi ...

  5. POJ3225

    题目链接:https://vjudge.net/problem/POJ-3225 解题思路:这道题要是不看题解以本渣新现在的实力确实是做不出来. 以区间为基础建立线段树. 当X=‘U', 将区间T内的 ...

  6. Python_OpenCV学习记录01安装

    Python照样快! 众所周知,虽然Python语法简洁,编写高效,但相比C/C++运行慢很多.然 而Python还有个重要的特性:它是一门胶水语言!Python可以很容易地扩展 C/C++.Open ...

  7. LNMP PHP升级脚本

    升级PHP前,请确认你的网站程序是否支持升级到的PHP版本,防止升级到网站程序不兼容的PHP版本,具体可以去你使用的PHP程序的官网查询相关版本支持信息.v1.3及以后版本大部分情况下也可以进行降级操 ...

  8. springboot整合mybatis报错

    java.sql.SQLException: The server time zone value 'Öйú±ê׼ʱ¼ä' is unrecognized or represents more ...

  9. [优文翻译]001.真正程序员该是什么样的(How To Be A Real Programmer)

    01.Real Programmers don't write specs -- users should consider themselves lucky to get any programs ...

  10. eclipse与idea部署项目的区别

    Eclipse会将web项目部署到 Tomcat 的安装目录下的webapps文件夹下IDEA会在操作系统盘的用户目录下新建一个目录,这个目录一般是你的IDEA的版本号目录1.启动项目 2. 根据地址 ...