tomcat性能调优
tomcat性能调优一般从两个方面进行调优:
- tomcat启动参数优化:即JVM优化(内存)
- Tomcat 容器自身参数的优化:( 线程、IO)
tomcat启动参数优化
server.xml
export SERVER_CONF="-config conf/sys.xml"
export JAVA_HOME=/usr/java/jdk1.8.0_111/
export JRE_HOME=/usr/java/jdk1.8.0_111/jre
JAVA_OPTS='
-server #JVM运行模式
-Xrs #减少JVM对操作系统信号(OS Signals)的使用
-Xmx4G #最大JAVA堆 max
-Xms4G #最小JAVA堆 start
-Xss256k #JAVA栈大小
-XX:NewSize=1G #新生代大小
-XX:MaxNewSize=1G #最大新生代大小
-XX:+DisableExplicitGC #忽略调用System.gc(),不会触发任何 GC
-XX:+UseConcMarkSweepGC #使用ParNew + CMS + Serial Old 的收集器组合进行内存回收。Serial Old 收集器将作为CMS 收集器出现Concurrent Mode Failure失败后的后备收集器使用
-XX:+CMSParallelRemarkEnabled #在使用 UseParNewGC 的情况下,尽量减少 mark 的时间
-XX:LargePageSizeInBytes=128m #指定JAVA堆的分页页面大小,内存页的大小不可设置过大
-XX:+UseFastAccessorMethods #将get,set方法转成本地代码,原始类型的快速优化
-XX:+UseCMSInitiatingOccupancyOnly #表示只有达到阀值时才进行CMS回收
-XX:CMSInitiatingOccupancyFraction=70 #使用cms作为垃圾回收,使用70%后开始CMS收集
-XX:SurvivorRatio=8 #新生代EDEN、FROM、TO的比例为8:1:1
-Xverify:none #禁用类验证
-Xnoclassgc #禁用类元数据回收
-Djava.net.preferIPv4Stack=true #获取到的机器名是完整的机器名
-Dfile.encoding=UTF-8 #文件编码
-Dcom.sun.management.jmxremote.ssl=false #JVISUALVM或JCONSOLE远程监控
-Dcom.sun.management.jmxremote.authenticate=false #远程监控
-Dcom.sun.management.jmxremote.port=10022 #远程监控
-Djava.rmi.server.hostname=10.206.2.180 #本机IP
上面讲到的工具都是作为快速的查看诊断工具的。如果要深入分析问题,可以选择使用内置的Java飞行记录器:Java Mission Control,需要打开以下两个选项。
-XX:+UnlockCommercialFeatures
-XX:+FlightRecorder
'
Tomcat 容器自身参数的优化:( 线程、IO)
1)单一配置方式
<Connector
port="8080"
protocol="org.apache.coyote.http11.Http11AprProtocol" --协议类型
disableUploadTimeOut="true" ----设置允许更长的超时连接
keepAliveTimeout="20000"
connectionTimeout="20000" --已接收,但未被处理的请求的等待超时时间 ms
URIEncoding="UTF-8" --URL编码字符集
minSpareThreads="100" --默认初始化和保持空闲的线程数
enableLookups="false" -- 关闭DNS反向查询
useURLValidationHack="false" --关闭url检查
maxTheads="1000" --处理请求线程的最大数目, 默认200
acceptCount="1000" --所用可能的线程都在使用时传入连接请求的最大长度
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" --设置压缩的文件类型
minProcessors="100"
maxProcessors="1000"
2)使用线程池的方式
<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" />
tomcat8.5默认使用线程池