Tomcat优化

Tomcat优化

一.配置文件优化

配置参数 说明
maxThreads Tomcat使用线程来处理接收的每个请求,这个值表示Tomcat可创建的最大的线程数,即支持的最大并发连接数,默认值是 200
acceptCount 指定当所有可以使用的处理请求的线程数都被使用时,可传入连接请求的最大队列长度,超过这个数的请求将不予处理,默认为 100 个
processorCache 进程缓冲器,可以提升并发请求。默认值是200,如果不做限制的话可以设置为-1,一般采用maxThreads的值或者-1
enablelookups 是否反查域名,以返回远程主机的主机名,取值为:true 或 false,如果设置为 false,则直接返回 IP 地址,为了提高处理能力,应设置为 false
URIEncoding 指定 Tomcat 容器的 URL 编码格式,网站一般采用UTF-8作为默认编码
maxKeepAliveRequests 指定一个长连接的最大请求数。默认长连接是打开的,设置为1时,代表关闭长连接;为-1时,代表请求数无限制
connnectionTimeout 网络连接超时,单位:毫秒,设置为 0 表示永不超时,这样设置有隐患的。通常默认 20000 毫秒就可以
compression 是否对响应的数据进行GZIP压缩,off:表示禁止压缩;on:表示允许压缩(文本将被压缩)、force:表示所有情况下都进行压缩,默认值为 off,压缩数据后可以有效的减少页面的大小,一般可以减小 1/3 左右,节省带宽。
compressionMinSize 表示压缩响应的最小值,只有当响应报文大小大于这个值的时候才会对报文进行压缩,如果开启了压缩功能,默认值就是 2048
compressableMimeType 压缩类型,指定对哪些类型的文件进行数据压缩
vim /usr/local/tomcat/conf/server.xml
......

二.JVM优化

2.1配置优化

环境规格以 2C4G 为例

配置添加在 Tomcat 的 bin 目录下 catalina.sh 里,位置在 cygwin=false 前。

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

2.2参数解释

-server        实现在多核服务器性能更佳
-Xms2048m -Xmx2048m 设置堆内存初始值和堆内存最大值一样大,般为物物理内存的 1/2
-Xmn768m     堆内新生代的大小,通过这个值也可以得到老生代的大小:-Xmx减去-Xmn。官方推荐配置为整个堆的 3/8
-XX:PermSize=1024m -XX:MaxPermSize=1024m  设置非堆内存初始值和非堆内存最大值一样大,一般为物理内存得到1/4,可以减少堆内存和非堆内存经常发生伸缩波动,影响系统响应时间
-XX:ParallelGCThreads=2  设置并行垃圾回收线程数,提高垃圾回收效率
-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/usr/local/tomcat/temp/oom.hprof   设置进程发生OOM异管退出会进行DUMP备份
-XX:+DisableExplicitGC     禁止调用system.gc(),防止误调用gc方法导致系统的 JVM 大起大落而使系统响应时间严重降低。
-Djava.awt.headless=true  避免在 Linux/Unix 环境下 Web 网页不能正常显示图片

三.系统内核参数优化

3.1修改etc/security/limits.conf

*                soft    nofile          65535			打开文件数
*                hard    nofile          65535
*                soft    nproc           65535			打开进程数
*                hard    nproc           65535
*                soft    memlock         unlimited		内存锁定不限制
*                hard    memlock         unlimited

3.2修改/etc./sysctl.conf

net.ipv4.tcp_syncookies =1				   开启SYNCookies
net.ipv4.tcp_tw_reuse = 1				   允许将TIME-WAIT sockets重新用于新的TCP连接,
net.ipv4.tcp_tw_recycle = 1				   开启TCP连接中TIME-WAIT sockets的快速回收
net.ipv4.tcp_fin_timeout = 30			   修改系统默认的fin TIMEOUT 时间

net.ipv4.ip_local_port_range = 1024 65535   外向连接的端口范围
net.ipv4.tcp max tw buckets= 5000           系统同时保持TIME WAIT最大数量         
net.ipv4.tcp_max_syn_backlog = 8192         SYN队列长度
net.ipv4.tcp_keepalive_time = 1200          发送keepalive探测包消息的频度

sysctl -p 

你可能感兴趣的:(tomcat,java,jvm)