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 下载安装下载地址:
进入bin目录,找到meter.bat文件,双击打开即可启动。
注意:如果想要效果更好的体现最好使用一个项目demo进行测试
4.1.2 配置第一步:保存测试用例
第二步:添加线程组,使用线程模拟用户的并发
1000个线程,每个线程循环10次,也就是tomcat会接收到10000个请求
第三步:添加http请求
这里我使用的是我的测试项目
第四步:添加请求监控
其中我们需要关注的就是 聚合报告 的数据
4.2 禁用AJP服务可以看到,禁用AJP服务后,平均响应时间和吞吐量会有所提升,不过测试不一定准确,需要多测试几次才能看出来是否有提升。
4.3 设置线程池通过审核制线程池,调整线程池相关的参数进行测试tomcat的性能
4.3.1 最大线程数为500,初始为50 <Executor 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性能不知道大家看的怎么样,感兴趣的小伙伴可以点赞关注一波,有问题的小伙伴可以在下面留言,博主看到了会第一时间回复大家,谢谢,大家加油~