【Web服务器】Tomcat的优化

文章目录

  • 前言
  • 一、配置文件优化
  • 二、系统内核优化
  • 三、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

你可能感兴趣的:(Web服务器,tomcat,架构,java)