文章目录
- 前言
- 一、配置文件优化
- 二、系统内核优化
- 三、JVM 优化
- 四、总结
前言
Tomcat默认安装下的缺省配置并不适合生产环境,它可能会频繁出现假死现象需要重启,只有通过不断压测优化才能让它最高效率稳定的运行。优化主要包括三方面,分别为操作系统优化(内核参数优化),Tomcat配置文件参数优化,Java虚拟机(JVM)调优。
一、配置文件优化
maxThreads
(最大线程数):Tomcat使用线程来处理接收的每个请求,这个值表示Tomcat可创建的最大的线程数,即支持的最大并发连接数,默认值是 200。
acceptCount
(等待队列数):指定当所有可以使用的处理请求的线程数都被使用时,可传入连接请求的最大队列长度,超过这个数的请求将不予处理,默认为 100 个。
processorCache
(进程缓冲):进程缓冲器,可以提升并发请求。默认值是200,如果不做限制的话可以设置为-1,一般采用maxThreads的值或者-1。
enableLookups
(关闭DNS反向解析):是否反查域名,以返回远程主机的主机名,取值为:true 或 false,如果设置为 false,则直接返回 IP 地址,为了提高处理能力,应设置为 false。
URIEncoding
(设置字符集编码为UTF-8):指定 Tomcat 容器的 URL 编码格式,网站一般采用UTF-8作为默认编码。
maxKeepAliveRequests
(连接保持最大请求数):指定一个长连接的最大请求数。默认长连接是打开的,设置为1时,代表关闭长连接;为-1时,代表请求数无限制。
connnectionTimeout
(连接超时时间):网络连接超时,单位:毫秒,设置为 0 表示永不超时,这样设置有隐患的。通常默认 20000 毫秒就可以。
compression
(开启网页压缩):是否对响应的数据进行GZIP压缩,off:表示禁止压缩;on:表示允许压缩(文本将被压缩)、force:表示所有情况下都进行压缩,默认值为 off,压缩数据后可以有效的减少页面的大小,一般可以减小 1/3 左右,节省带宽。
二、系统内核优化
文件 | 参数 |
---|---|
/etc/security/limits.conf | nofile (打开文件数) nproc (打开进程数) memlock(最大锁定内存地址空间) rss(最大持久设置大小) |
/etc/sysctl/conf (网卡优化) | net.ipv4.tcp tw recycle = 1(开启TCP连接中TIME-WAIT sockets的快速回收) net.ipv4.tcp tw reuse = 1(允许将TIME-WAIT sockets重新用于新的TCP连接) net.ipv4.ip_local_port_range = 1024 65000 (外向连接的端口范围) |
三、JVM 优化
JVM优化主要是在catalina.sh
文件中添加JAVA_OPTS
参数,以及做相关配置参数
vim /usr/local/tomcat/bin/catalina.sh
......
JAVA_OPTS="$JAVA_OPTS -server -Xms2048m -Xmx2048m -Xmn768m -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/local/tomcat/temp/oom.hprof -XX:ParallelGCThreads=2 -XX:PermSize=1024m -XX:MaxPermSize=1024m -Djava.awt.headless=true -XX:+DisableExplicitGC" cygwin=false
参数含义:
-server实现在多核服务器性能更佳
-Xms2048m -Xmx2048m 设置堆内存初始值和堆内存最大值一样大,一般为物理内存的1/2
-XX:PermSize=1024m -XX:MaxPermSize=1024m 设置非堆内存初始值和非堆内存最大值一样大,一般为物理内存的1/4,可以减少推内存和非堆内存经常发座徘缩波动,影幅系统确威对间前
-XX:ParallelGCThreads=2 设置并行垃圾回收线程数,提高垃圾回收效率.当 CPU 数量小于8,此值建议配置等于 CPU 数量。
-XX:+HeapDumpOnOutOfMemoryError 表示当JVM发生OOM时,自动生成DUMP文件
-XX:HeapDumpPath=/usr/local/tomcat/temp/oom.hprof 表示生成DUMP文件的路径
-XX:+DisableExplicitGC 禁止调用System.gc(),防止误调用gc方法导致系统的JVM大起大落而使系统响应时间严重降低
四、总结
想要更深入学习相关配置知识可以访问以下网址:
http://tomcat.apache.org/tomcat-9.0-doc/config/http.html