JVM调优实战之tomcat参数优化

本文介绍了如何通过禁用AJP服务、设置合理的线程池参数、调整最大等待队列和切换到nio2模式来提升Tomcat服务器的吞吐量,同时提醒读者注意环境因素对调优的影响。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

优化吞吐量

1、禁用AJP服务

JAP:AJP(Apache JServer Protocol)是定向包协议 。WEB服务器和Servlet容器通过TCP连接来交互;为 了节省SOCKET创建的昂贵代价,WEB服务器会尝试维护一个永久TCP连接到servlet容器,

并且在多个请求和响应周 期过程会重用连接。

tomcat在server.xml中配置了两种连接器。

1:连接监听8080端口,负责建立http练剑,浏览器访问tomact服务的web应用时,使用的就是这个连接器

2:连接接听8009端口,负责和其他的http服务器建立连接,tomcat与其他http服务及城市,需要用到这个连接器。

nginx+tomcat的架构,所以用不着AJP协议。修改conf下的service.xml文件,禁用AJP服务即可。

(注释掉即可,有的tomcat默认即为注释掉的)

 

2、设置执行器(线程池)

频繁地创建线程会造成性能浪费,所以使用线程池来优化: 在tomcat中每一个用户请求都是一个线程,所以可以使用线程池提高性能。

修改server.xml文件:参数说明:

  maxThreads:最大并发数,默认设置 200,一般建议在 500 ~ 1000,根据硬件设施和业务来判断

  minSpareThreads:Tomcat 初 始 化 时 创 建 的 线 程 数 , 默 认 设 置 25

  prestartminSpareThreads: 在 Tomcat 初始化的时候就初始化 minSpareThreads 的参数值,如果不等于 true, minSpareThreads 的值就没啥效果了

  maxQueueSize,最大的等待队列数,超过则拒绝请求

 

重新启动tomcat查看结果,发现主要参数有变化(吞吐量发现有提升,但其余数值变坏,调优没有绝对的数值。综合调整。最后选择最优解)。

3、设置最大等待队列:maxQueueSize,最大的等待队列数,超过则拒绝请求

    默认情况下,请求发送到tomcat,如果tomcat正忙,那么该请求会一直等待。这样虽然 可以保证每个请求都能请求 到,但是请求时间就会边长。

    有些时候,我们也不一定要求请求一定等待,可以设置最大等待队列大小,如果超过就不等待了。这样虽然有些请 求是失败的,但是请求时间会变短。

4、设置nio2的运行模式

tomcat的运行模式有3种:

1.bio 默认的模式,性能非常低下,没有经过任何优化处理和支持.

2.nio 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)更好的并发运行性能。

3.apr 安装起来最困难,但是从操作系统级别来解决异步的IO问题,大幅度的提高性能. 推荐使用nio,不过,在 tomcat8中有最新的nio2,速度更快,建议使用nio2. 设置nio2:

protocol="org.apache.coyote.http11.Http11Nio2Protocol"

结果:发现吞吐量还变坏了。 理论上应该变好。可能跟运行环境有关调优时要根据环境进行设置。

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cc_南柯一梦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值