在CentOS下对Tomcat进行性能调优是一个涉及多个层面的过程,主要包括硬件资源优化、操作系统配置调整、Tomcat自身参数设置以及JVM参数优化等。以下是一些具体的调优建议和步骤:
/etc/sysctl.conf
文件中的参数:net.core.somaxconn 65535
net.ipv4.tcp_tw_reuse 1
net.ipv4.tcp_tw_recycle 1
fs.file-max 65536
/etc/security/limits.conf
文件,增加以下行:* soft nofile 65536
* hard nofile 65536
/etc/rc.local
文件,添加以下命令:echo never /sys/kernel/mm/transparent_hugepage/enabled
echo never /sys/kernel/mm/transparent_hugepage/defrag
server.xml
文件中的 Executor
元素调整最大线程数(maxThreads)和最小空闲线程数(minSpareThreads)。例如:<Executor name="tomcatThreadPool" namePrefix="catalina-exec-" maxThreads="500" minSpareThreads="50" maxQueueSize="100" />
server.xml
中添加以下配置:<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" compression="on" />
Connector
配置以启用NIO或NIO2:<Connector port="8080" protocol="org.apache.coyote.http11.Http11Nio2Protocol" connectionTimeout="20000" redirectPort="8443" />
-Xms
和 -Xmx
参数设置初始堆大小和最大堆大小,避免频繁的堆内存调整。例如:export CATALINA_OPTS="-server -Xms512m -Xmx1024m -XX:PermSize=256m -XX:MaxPermSize=512m -XX:UseG1GC"
-XX:UseG1GC
或 -XX:UseParallelGC
参数指定。例如:export CATALINA_OPTS="$CATALINA_OPTS -XX:+UseG1GC"
-XX:NewRatio
参数设置。例如:export CATALINA_OPTS="$CATALINA_OPTS -XX:NewRatio=2"
-XX:ParallelGCThreads
参数设置并行GC线程数,以提高垃圾回收的效率。例如:export CATALINA_OPTS="$CATALINA_OPTS -XX:ParallelGCThreads=4"
在进行上述优化时,请根据实际情况逐步调整并观察应用表现,避免过度优化。同时,确保优化措施不会影响应用的稳定性和安全性。