当前位置:首页 > 公众号精选 > 架构师社区
[导读]一、前言 tomcat 服务器在JavaEE项目中使用率非常高,所以在生产环境对tomcat的优化也变得非常重要了,对于tomcat的优化,主要是从2个方面入手,一是tomcat本身的配置,另一个是tomcat所运行的Jvm虚拟机的调优 二、Tomcat配置优化 2.1 下载安装tomcat 案例中

一、前言

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

二、Tomcat配置优化

2.1 下载安装tomcat

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

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

2.2 配置修改

# 进入tomcat配置文件夹cd apache-tomcat-8.5.47/conf/# 需要配置文件,配置tomcat的管理用户vim tomcat-users.xml 

写入以下内容:

 <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" > <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地址后,点击 首页中 ServerStatus,输入用户名密码 tomcat/tomcat

提高网站访问性能——Tomcat优化进入页面,我们需要关注的就是其中JVM的列表参数:

Eden Space:年轻代中的Eden区

Survivor Space:年轻代中的Survivor 区

Tenured Gen:老年代-养老区

其中 EdenSpaceSurvivorSpaceTenuredGen属于堆内存,而下面的三个( CodeCacheCompressedClassSpaceMetaspace)属于非堆内存

Code Cache:代码缓存区

Compressed Class Space:压缩类空间

Metaspace:元空间

三、Tomcat优化

3.1 禁用AJP连接

在服务状态页面可以看到,默认状态下回启用AJP连接,并且占用 8011端口提高网站访问性能——Tomcat优化什么是AJP呢?

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

web客户端访问tomcat服务器上的JSP组件的两种方式,如下图所示:提高网站访问性能——Tomcat优化我们一般是使用Nginx+tomcat的架构,所以用不着AJP协议,所以把AJP连接禁用。修改conf下的Server.xml文件,将AJP服务禁用掉即可。

					
  1. port="8011" protocol="AJP/1.3" redirectPort="8443" />

提高网站访问性能——Tomcat优化

重启tomcat,查看效果:可以看到AJP服务已经不存在了

3.2 执行器(线程池)

在tomcat中每一个用户请求都是一个线程,所以可以使用线程池提高性能 修改conf/server.xml文件:

<Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="50"  prestartminSpareThreads="true" maxQueueSize="100"/>    <Connector executor="tomcatThreadPool" port="8000"  protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" />

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

提高网站访问性能——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" />

提高网站访问性能——Tomcat优化

四、性能测试

4.1 使用Apache Jmeter 进行测试

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

4.1.1 下载安装

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

进入bin目录,找到meter.bat文件,双击打开即可启动。提高网站访问性能——Tomcat优化

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

4.1.2 配置

第一步:保存测试用例

第二步:添加线程组,使用线程模拟用户的并发提高网站访问性能——Tomcat优化1000个线程,每个线程循环10次,也就是tomcat会接收到10000个请求提高网站访问性能——Tomcat优化第三步:添加http请求 这里我使用的是我的测试项目提高网站访问性能——Tomcat优化提高网站访问性能——Tomcat优化

第四步:添加请求监控提高网站访问性能——Tomcat优化

4.1.3 启动测试:

提高网站访问性能——Tomcat优化

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

提高网站访问性能——Tomcat优化

4.2 禁用AJP服务

提高网站访问性能——Tomcat优化

提高网站访问性能——Tomcat优化

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

4.3 设置线程池

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

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

测试结果:提高网站访问性能——Tomcat优化

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

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

4.4 设置nio的运行模式

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

提高网站访问性能——Tomcat优化

可以看到,平均响应时间有所缩短,吞吐量有所提升,所以从中可以看出,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性能不知道大家看的怎么样,感兴趣的小伙伴可以点赞关注一波,有问题的小伙伴可以在下面留言,看到了会第一时间回复大家,谢谢,大家加油~

特别推荐一个分享架构+算法的优质内容,还没关注的小伙伴,可以长按关注一下:

提高网站访问性能——Tomcat优化

提高网站访问性能——Tomcat优化

提高网站访问性能——Tomcat优化

长按订阅更多精彩▼

提高网站访问性能——Tomcat优化

如有收获,点个在看,诚挚感谢

免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
关闭
关闭