- 关闭Tomcat的监听端口,默认为8005
<Server port="8005" shutdown="SHUTDOWN">
#如果要禁用端口则修改为:
<Server port="-1" shutdown="SHUTDOWN">
- 链接器Connector 参数优化配置
<Connector
executor="tomcatThreadPool" //连接数限制修改配置的名字
port="8080" //tomcat的端口,默认为8080
#protocol:
#Tomcat 8 设置 nio2 更好:org.apache.coyote.http11.Http11Nio2Protocol
#Tomcat 6,7 设置 nio 更好:org.apache.coyote.http11.Http11NioProtocol
#Tomcat 8 设置 APR 性能飞快:org.apache.coyote.http11.Http11AprProtocol
protocol="org.apache.coyote.http11.Http11Nio2Protocol"
connectionTimeout="60000" //Connector接受一个连接后等待的时间(milliseconds),默认值是60000
maxConnections="10000" //这个值表示最多可以有多少个socket连接到tomcat上
redirectPort="8443" //SSL端口号
enableLookups="false" //禁用DNS查询
acceptCount="100" //当tomcat起动的线程数达到最大时,接受排队的请求个数,默认值为100
maxPostSize="10485760" //设置由容器解析的URL参数的最大长度,-1(小于0)为禁用这个属性,默认为2097152(2M) 请注意, FailedRequestFilter 过滤器可以用来拒绝达到了极限值的请求。
maxHttpHeaderSize="8192" //http请求头信息的最大长度,超过此长度的部分不予处理。一般8K。
compression="on" //是否启用GZIP压缩 on为启用(文本数据压缩) off为不启用, force 压缩所有数据
disableUploadTimeout="true" //这个标志允许servlet容器使用一个不同的,通常长在数据上传连接超时。 如果不指定,这个属性被设置为true,表示禁用该时间超时。
compressionMinSize="2048" //当超过最小数据大小才进行压缩
acceptorThreadCount="2" //用于接受连接的线程数量。增加这个值在多CPU的机器上,尽管你永远不会真正需要超过2。 也有很多非维持连接,您可能希望增加这个值。默认值是1。
compressableMimeType= "text/html,text/plain,text/css,application/javascript,application/json,application/x-font-ttf,application/x-font-otf,image/svg+xml,image/jpeg,image/png,image/gif,audio/mpeg,video/mp4" //配置想压缩的数据类型
URIEncoding="utf-8" //网站一般采用UTF-8作为默认编码。
processorCache="20000" //协议处理器缓存的处理器对象来提高性能。 该设置决定多少这些对象的缓存。-1意味着无限的,默认是200。 如果不使用Servlet 3.0异步处理,默认是使用一样的maxThreads设置。 如果使用Servlet 3.0异步处理,默认是使用大maxThreads和预期的并发请求的最大数量(同步和异步)。
tcpNoDelay="true" //如果设置为true,TCP_NO_DELAY选项将被设置在服务器套接字,而在大多数情况下提高性能。这是默认设置为true。
connectionLinger="5" //秒数在这个连接器将持续使用的套接字时关闭。默认值是 -1,禁用socket 延迟时间。
server="Server Version 11.0" //隐藏Tomcat版本信息,首先隐藏HTTP头中的版本信息
/>
- tomcat线程池
默认值:被注释了了
<!-- <Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="150" minSpareThreads="4"/> -->
修改示例
<Executor
name="tomcatThreadPool" //被链接器配置识别的名字
namePrefix="catalina-exec-" //所创建的每个线程的名称前缀,一个单独的线程名称为 namePrefix+threadNumber
maxThreads="500" //最大并发数,默认设置 200,一般建议在 500 ~ 800,根据硬件设施和业务来判断
minSpareThreads="30" //omcat 初始化时创建的线程数,默认设置 25
maxIdleTime="60000" //如果当前线程大于初始化线程,那空闲线程存活的时间,单位毫秒,默认60000=60秒=1分钟
prestartminSpareThreads = "true" //在 Tomcat 初始化的时候就初始化 minSpareThreads 的参数值,如果不等于 true,minSpareThreads 的值就没啥效果了
threadPriority=5 //线程池中线程优先级,默认值为5,值从1到10。
maxQueueSize = (Int的最大值) //最大的等待队列数, 也就是在被执行前最大线程排队数目,默认为Int的最大值,也就是广义的无限。除非特殊情况,这个值不需要更改,否则会有请求不会被处理的情况发生
className:线程池实现类,未指定情况下,默认实现类为org.apache.catalina.core.StandardThreadExecutor。如果想使用自定义线程池首先需要实现 org.apache.catalina.Executor接口。线程池配置完成后需要在 Connector中指定
/>
- 自动部署功能
<Host appBase="webapps" autoDeploy="true" name="localhost" unpackWARs="true">
#如果想关闭自动部署功能
<Host appBase="webapps" autoDeploy="false" name="localhost" unpackWARs="true">
- AJP端口配置
<Connector
port="8009" //端口,如果多个tomcat部署在一个服务器上,则要修改次处
protocol="AJP/1.3"
address="127.0.0.1"
redirectPort="8443" />
- 集群配置 Engine标签内
#默认这条语句是被注释起来的:
<!--
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster"/>
-->
#开启集群,我们只需要吧这条注释放开就可以了
- 上面的情况是tomcat都部署到了不同的服务器上,所用才用默认的配置都是不会出错的,但是,如果我们在一台服务器上配置了多个tomcat,那么问题就来了,会有端口冲突的问题,所用我们得配置更多的信息
<!--下面的代码是开启集群和实现session复制功能-->
<Cluster className="org.apache.catalina.ha.tcp.SimpleTcpCluster" channelSendOptions="6">
<Channel className="org.apache.catalina.tribes.group.GroupChannel">
<Receiver className="org.apache.catalina.tribes.transport.nio.NioReceiver"
address="192.168.100.63" <!--这里填写本机IP地址-->
port="5000" //不同的tomcat配置不同的端口
selectorTimeout="100" />
</Channel>
</Cluster>
网友评论