一、前言
tomcat 服务器在JavaEE项目中使用率非常高,所以在生产环境对tomcat的优化也变得非常重要了,对于tomcat的优化,主要是从2个方面入手,一是tomcat本身的配置,另一个是tomcat所运行的Jvm虚拟机的调优
二、Tomcat配置优化
2.1 下载安装tomcat
案例中使用的Tomcat版本是 8.0+ 版本
下载安装:https://tomcat.apache.org/download-80.cgi
![597ddf2f3a737beddc935a2abd88f884.png](https://i-blog.csdnimg.cn/blog_migrate/6fa30db7d3d1d3a5987a82e34f0aa885.jpeg)
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
![5b93dcf63be5ee5feb259925e814d5d3.png](https://i-blog.csdnimg.cn/blog_migrate/0f536f66cc1e1e5a3493d1181a633899.jpeg)
进入页面,我们需要关注的就是其中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:元空间
![3588337d17d6b830cf06ebd210af6a88.png](https://i-blog.csdnimg.cn/blog_migrate/7eba7c4393c3b160e9410257dea9e8e8.jpeg)
三、Tomcat优化
3.1 禁用AJP连接
在服务状态页面可以看到,默认状态下回启用AJP连接,并且占用8011
端口
![71149a1ce140f29dc2d1b2c97b3f22eb.png](https://i-blog.csdnimg.cn/blog_migrate/2d88b991ece652627dced4cf7a57ff2f.png)
什么是AJP呢?
AJP(Apache jServer Protocol)
AJP13协议是面向包的,WEB服务器和Servlet容器通过TCP连接来交互;为了节省SOCKET创建的昂贵代价,WEB服务器会尝试维护一个永久TCP容器,并且在多个请求赫尔响应周期过程会重用连接。
web客户端访问tomcat服务器上的JSP组件的两种方式,如下图所示:
![81267a5c6bf784f6b5cb91d1abee567a.png](https://i-blog.csdnimg.cn/blog_migrate/88982c087f3a03d7fbb9d031b2d94fbf.jpeg)
我们一般是使用Nginx+tomcat的架构,所以用不着AJP协议,所以把AJP连接禁用。
修改conf下的Server.xml文件,将AJP服务禁用掉即可。
<Connector port="8011" protocol="AJP/1.3" redirectPort="8443" />
![52d2ccc25c2a0798b69d347f3e7db05b.png](https://i-blog.csdnimg.cn/blog_migrate/ff914e2106389bf85e568b6ab4eb8b78.png)
重启tomcat,查看效果:
![3fdcfc9bf0f44e8827de5d6dac2087d5.png](https://i-blog.csdnimg.cn/blog_migrate/9edd7de9efba3806e7d83dfca1ce0f16.jpeg)
可以看到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,查看效果
![b0cc61b814fa45be56adeded47e4a423.png](https://i-blog.csdnimg.cn/blog_migrate/964787a186ffb78fbd8417ca1a6d8f83.png)
在页面中现实最大线程为 -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" />
![9a29be3333597833548ff176b3d30095.png](https://i-blog.csdnimg.cn/blog_migrate/61b5ae0d6f052a7a156c7dc6fa60f8e5.png)
四、性能测试
4.1 使用Apache Jmeter 进行测试
Apache Jmeter 是开源的压力测试工具,我们借助此工具进行测试,将测试出tomcat的吞吐量等信息
4.1.1 下载安装
下载地址:http://jmeter.apache.org/download_jmeter.cgi
![7b8247c405bdbd57b7b1b49b9feac410.png](https://i-blog.csdnimg.cn/blog_migrate/85ce7bcc35ae5f366d91f6444261496f.jpeg)
进入bin目录,找到meter.bat文件,双击打开即可启动。
![c6059f2f0d6cf45e5c6267659c4c1ecc.png](https://i-blog.csdnimg.cn/blog_migrate/3041c73f9b383495040bdd45fec226e4.png)
注意:如果想要效果更好的体现最好使用一个项目demo进行测试
4.1.2 配置
第一步:保存测试用例
![fc76b148eafc26bfbc7420fccb19c219.png](https://i-blog.csdnimg.cn/blog_migrate/9285940306904cfe892897434fa41271.jpeg)
第二步:添加线程组,使用线程模拟用户的并发
![9ef8defde15d16cac5263ec96368fc84.png](https://i-blog.csdnimg.cn/blog_migrate/afbd76c9f5aa4211eb7292160fe2ccf7.png)
1000个线程,每个线程循环10次,也就是tomcat会接收到10000个请求
![540a0423254df1e29cbb458f71a14e18.png](https://i-blog.csdnimg.cn/blog_migrate/d984d37d943ecf2bfc7d784b314ef553.jpeg)
第三步:添加http请求
这里我使用的是我的测试项目
![9fa50c0fb07efb96fe9dc82f04f237e6.png](https://i-blog.csdnimg.cn/blog_migrate/9b363c0e9ce928c70d2a64c8ca3e57b1.jpeg)
![ce8fa888baee69283da14c9378fd808e.png](https://i-blog.csdnimg.cn/blog_migrate/49a16c7212f83e0941d8192853cc8081.jpeg)
第四步:添加请求监控
![b9edfc097c97d06e73e57456b94f0757.png](https://i-blog.csdnimg.cn/blog_migrate/a35252a145fb7def16d0ee71a029a26a.jpeg)
4.1.3 启动测试:
![fe74e63a6dcadf9f93145db25476df44.png](https://i-blog.csdnimg.cn/blog_migrate/e06924264016bef42649066c68ba262b.jpeg)
其中我们需要关注的就是 聚合报告 的数据
![67f8df213748198735f3a2444473db18.png](https://i-blog.csdnimg.cn/blog_migrate/bc2281a3c760c3e64e05cbe5853e5996.jpeg)
4.2 禁用AJP服务
![52d2ccc25c2a0798b69d347f3e7db05b.png](https://i-blog.csdnimg.cn/blog_migrate/ff914e2106389bf85e568b6ab4eb8b78.png)
![6e5e65f0087e15ba1e6585b6680598ed.png](https://i-blog.csdnimg.cn/blog_migrate/4f7202bfe91639e8eaff3158d273cdbe.jpeg)
可以看到,禁用AJP服务后,平均响应时间和吞吐量会有所提升,不过测试不一定准确,需要多测试几次才能看出来是否有提升。
4.3 设置线程池
通过审核制线程池,调整线程池相关的参数进行测试tomcat的性能
4.3.1 最大线程数为500,初始为50
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
maxThreads="500" minSpareThreads="50" prestartminSpareThreads="true" maxQueueSize="100"/>
测试结果:
![6fe8455b4a7923f5e6fb20c2536ad0f3.png](https://i-blog.csdnimg.cn/blog_migrate/bd894cea810943fbbb34ee0298c977ac.jpeg)
吞吐量为 5.8/秒,性能有所提升
是否是线程越多,速度越快呢,在实际测试中,并不是线程越多性能越高,单靠提升线程数量是不能一直得到性能提升的。
4.4 设置nio的运行模式
<Connector executor="tomcatThreadPool" port="8000" protocol="org.apache.coyote.http11.Http11Nio2Protocol"
connectionTimeout="20000"
redirectPort="8443" />
![b1cdf106d49f3ce703c6a85f78437aa7.png](https://i-blog.csdnimg.cn/blog_migrate/f38dff19b0f277eea9723f9452cd0b4a.jpeg)
可以看到,平均响应时间有所缩短,吞吐量有所提升,所以从中可以看出,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"
![ac721ed69ffdeac3d8b8c477ce3dd4a0.png](https://i-blog.csdnimg.cn/blog_migrate/2a80ba48d4046950ef71c2c48d15759c.jpeg)
![f6f3d8dcb1cf6482670b9452a3d147d9.png](https://i-blog.csdnimg.cn/blog_migrate/07285cb813d4e1a8f127cf016bf25818.jpeg)
可以看到,平均响应时间有所缩短,吞吐量有所提升
五、总结
今天的tomcat性能不知道大家看的怎么样,感兴趣的小伙伴可以点赞关注一波,有问题的小伙伴可以在下面留言,博主看到了会第一时间回复大家,谢谢,大家加油~
原文链接:提高网站访问性能之Tomcat优化 - 牧小农的夏天 - 博客园
作者:牧小农的夏天
原出处:博客园
如有侵犯,立即删除