Tomcat性能优化总结

层级优化!(JAVA_OPTS参数和主要元素的优化)javascript

Tomcat大体元素架构:server--->service-->Engine-->Host-->Contextcss

Tomcat有可使用三种协议:HTTPAJPHTTPShtml

tomcat默认采用的BIO模型java

tomcat的运行模式有3种bio,nio,apr(额外安装),例如:web

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

Tomcat各个元素里面都有listener监听器,由Service层的链接器connector经过线程池(Thread Pool)调用执行器(Executor),Connector的做用是接收链接请求,建立Request和Response对象用于和请求端交换数据;而后分配线程携带该request和response交给绑定的Engine来处理,最后把处理后的Request和Response返回给客户端。windows

tomcat在启动时,会将web项目中WEB-INF/web.xml和本身的conf/web.xml进行合并,而后在ContextConfig类下的configureContext()统一解析这些内容浏览器

因此,没必要要的配置要删除,以减小Tomcat解析成本。tomcat

像在conf/web.xml的DefaultServlet或JspServlet,jspmap,mime,欢迎页面按需来配置。安全

conf/server.xml的Listener监听器中,VersionLoggerListener做用是显示版本和JDK环境,能够删除;AprLifecycleListener做用:加载APR库使用,这个配置仅当connector的protocol设置为AJP/1.3时有用,若是非AJP/1.3,能够删除。

GlobalResourcesLifecycleListener做用于全局资源

GlobalNamingResources能够定义全局资源,能够看出,这个tomcat的默认配置是经过读取$TOMCAT_HOME/ conf/tomcat-users.xml实现的。tomcat-user.xml用于定义tomcat管理页面相关配置,若是不登陆管理界面能够删掉。

tomcat须要集成到Apache服务器时才使用这个<connector protocol=”AJP/1.3”/>

Server元素的port监听关闭服务的请求

Connector

port:指定服务器端要建立的端口号,并在这个断口监听来自客户端的请求

minProcessors:服务器启动时建立的处理请求的线程数

maxProcessors:最大能够建立的处理请求的线程数

enableLookups:若是为true,则能够经过调用request.getRemoteHost()进行DNS查询来获得远程客户端的实际主机名,若为false则不进行DNS查询,而是返回其ip地址

redirectPort:指定服务器正在处理http请求时收到了一个SSL传输请求后重定向的端口号

acceptCount:指定当全部可使用的处理请求的线程数都被使用时,能够放处处理队列中的请求数,超过这个数的请求将不予处理

maxConnections:达到这个值以后,将继续接受链接,可是不处理,能继续接受多少根据acceptCount的值

minSpareThreads:最小空闲线程数

connectionTimeout:指定超时的时间数(以毫秒为单位)

tomcat默认链接池有限制,能够为connector配置本身的链接池,例如:

<Connector executor="tomcatThreadPool"port="8080" protocol="HTTP/1.1"

jvm参数优化

tomcat是用Java写的,就要运行在jvm上,垃圾处理方式等都要遵循jvm的方式。tomcat中设置jvm参数在 catalina.sh(Linux)和catalina.bat(windows)中,以JAVA_OPTS变量存储。

各参数详解:

-Xms:设置JVM初始内存大小(默认是物理内存的1/64)

-Xmx:设置JVM可使用的最大内存(默认是物理内存的1/4,建议:物理内存80%)

-Xmn:设置JVM最小内存(128-256m就够了,通常不设置)

 

-XX:PermSize :为JVM启动时Perm的内存大小

-XX:MaxPermSize :为最大可占用的Perm内存大小(默认为32M)

-XX:MaxNewSize,默认为16M

-XX:NewSize :默认为2M,此值设大可调大新对象区,减小Full
GC次数

-XX:NewRatio :改变新旧空间的比例,意思是新空间的尺寸是旧空间的1/8(默认为8)

-XX:SurvivorRatio :改变Eden对象空间和残存空间的尺寸比例,意思是Eden对象空

间的尺寸比残存空间大survivorRatio+2倍(缺省值是10)

-XX:userParNewGC 可用来设置并行收集【多CPU】

-XX:ParallelGCThreads 可用来增长并行度【多CPU】

-XXUseParallelGC 设置后可使用并行清除收集器【多CPU】

1. conf/server.xml中Executor对应的相关参数

<!--链接池设置-->
<Executor 
name="tomcatThreadPool" --线程池名
namePrefix="catalina-exec-" --线程名称前缀 namePrefix+threaNumber
maxThreads="1000" --池中最大线程数
minSpareThreads="100" --活跃线程数 会一直存在
maxIdleTime="60000" --线程空闲时间,超过该时间,线程会被销毁 ms
maxQueueSize="Integer.MAX_VALUE" --被执行前线程的排队数目
prestartminSpareThreads="false" --启动线程池时,是否启用minSpareThreads部分线程
threadPriority="5" --线程池中线程优先级 1~10
className="org.apache.catalina.core.StandardThreadExecutor" --线程实现类 自定义线程需时间 org.apache.catalina.Executor类
/>
<!--当配置了链接池时,须要配置该链接器-->
<Connector 
executor="tomcatThreadPool" --线程池名
port="8080" 
protocol="org.apache.coyote.http11.Http11AprProtocol"
connectionTimeout="20000"
redirectPort="8443" />

2.conf/server.xml中Connector对应的相关参数


<Connector 
port="8080" 
protocol="org.apache.coyote.http11.Http11AprProtocol" --协议类型 
disableUploadTimeout="true"
keepAliveTimeout="20000"
connectionTimeout="20000" --已接受,但未被处理的请求的等待超时时间 ms
redirectPort="8443" --安全通讯的转发端口 
URIEncoding="UTF-8"--URL编码字符集
minSpareThreads="100" --默认初始化和保持空闲的线程数
enableLookups="false"--关闭DNS反向查询
useURIValidationHack="false" --关闭没必要要的检查
maxThreads="1000" --处理请求线程的最大数目 未配置为200 此属性会被忽略
acceptCount="1000" --所用可能的线程都在使用时传入链接请求的最大长度
disableUploadTimeout="true" --设置容许更长的超时链接
maxConnections="1000"--接受和处理的最大链接数(nio/nio2 1000,apr 8192)
maxHttpHeaderSize="8192"--请求和响应http头的最大大小 8k
tcpNoDelay="true" --tcp不延迟
compression="on"--是否启用压缩 on off force 
compressionMinSize="2048" --压缩前数据最小值 2k byte
noCompressionUserAgents="gozilla,traviata" --设置哪些浏览器不压缩
compressableMimeType="text/html,text/xml,text/css,application/javascript,text/plain" --设置压缩的文件类型
/>

3. 有关 JAVA_OPTS

set JAVA_OPTS=
-server 
-Xms1000M 
-Xmx1000M #-Xms与-Xmx设成同样的值,避免JVM由于频繁的GC致使性能大起大落
-Xss512k 
-XX:+AggressiveOpts 
-XX:+UseBiasedLocking 
-XX:+DisableExplicitGC 
-XX:MaxTenuringThreshold=15 
-XX:+UseConcMarkSweepGC 
-XX:+UseParNewGC 
-XX:+CMSParallelRemarkEnabled 
-XX:+UseCMSCompactAtFullCollection 
-XX:LargePageSizeInBytes=128m 
-XX:+UseFastAccessorMethods 
-XX:+UseCMSInitiatingOccupancyOnly

-Djava.awt.headless=true

4. 禁用8005端口

telnet localhost 8005 而后输入 SHUTDOWN 就能够关闭 Tomcat,为了安全咱们要禁用该功能

默认值:

<Server port="8005" shutdown="SHUTDOWN">
修改成:

<Server port="-1" shutdown="SHUTDOWN">---------------------

相关文章
相关标签/搜索