写点什么

JVM 性能优化(四)提高网站访问性能之 Tomcat 优化,java 程序开发实用教程邱加永答案

作者:Java高工P7
  • 2021 年 11 月 10 日
  • 本文字数:1929 字

    阅读完需:约 6 分钟

</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:元空间


![在这里插入图片描述](https://img-blog.csdnimg.cn/20200504124538659.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shad


《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》
浏览器打开:qq.cn.hn/FTe 免费领取
复制代码


ow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzE0OTk2NDIx,size_16,color_FFFFFF,t_70)


三、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="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/秒,性能有所提升


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

用户头像

Java高工P7

关注

还未添加个人签名 2021.11.08 加入

还未添加个人简介

评论

发布
暂无评论
JVM性能优化(四)提高网站访问性能之Tomcat优化,java程序开发实用教程邱加永答案