Tomcat_优化

简述

Tomcat,JavaEE服务器

基本配置

cd apache‐tomcat‐8.5.34/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,managergui,manager"/> 

#保存退出

#如果是tomcat7,配置了tomcat用户就可以登录系统了,但是tomcat8中不行,还需要修改 另一个配置文件,否则访问不了,提示403
vim webapps/manager/META‐INF/context.xml

#将Valve的内容注释掉

<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\.Cs rfPreventionFilter\$LruCache(?:\$1)?|java\.util\.(?:Linked)?HashMap"/> 
</Context> 

#保存退出即可

优化

禁用AJP连接

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

编辑conf/server.xml
注释掉一下代码:

<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" />

线程池优化

在tomcat中每一个用户请求都是一个线程,所以可以使用线程池提高性能。

修改server.xml文件:

<!‐‐将注释打开‐‐> 
<Executor name="tomcatThreadPool" namePrefix="catalina‐exec‐"  maxThreads="500" minSpareThreads="50"  prestartminSpareThreads="true" maxQueueSize="100"/> 
<!‐‐在Connector中设置executor属性指向上面的执行器‐‐> 
<Connector executor="tomcatThreadPool"  port="8080" protocol="HTTP/1.1"  connectionTimeout="20000"  redirectPort="8443" />

参数说明:
maxThreads:大并发数,默认设置 200,一般建议在 500 ~ 1000,根据硬件设施和业务来判断 minSpareThreads:Tomcat 初始化时创建的线程数,默认设置 25
prestartminSpareThreads: 在 Tomcat 初始化的时候就初始化 minSpareThreads 的参数值,如果不等于 true,minSpareThreads 的值就没啥效果了
maxQueueSize,大的等待队列数,超过则拒绝请求

设置运行模式

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

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

apr:安装起来困难,但是从操作系统级别来解决异步的IO问题,大幅度的提高性能。

在tomcat8中有新的nio2,速度更快,建议使用nio2。

设置方式:

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

优化案例

基本压测参数:500线程,循环5次

Tomcat默认配置:
在这里插入图片描述
1、禁用AJP连接
在这里插入图片描述
2、配置线程池

<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
        maxThreads="1000" minSpareThreads="50" prestartminSpareThreads="true"/>

在这里插入图片描述

<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
        maxThreads="1500" minSpareThreads="50" prestartminSpareThreads="true"/>

在这里插入图片描述
备注:单纯靠提升线程数量是不能一直得到性能提升的。

3、配置运行模式

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

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值