【Web服务器】Tomcat的优化

news/2024/11/25 21:42:26/

文章目录

  • 前言
  • 一、配置文件优化
  • 二、系统内核优化
  • 三、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.confnofile (打开文件数)
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


http://www.ppmy.cn/news/238993.html

相关文章

录音如何转换成mp3格式

录音怎如何转换成mp3格式?因为我们知道录音的格式有很多种,其中常见的有WAV格式(Waveform Audio File Format):是一种无损音频文件格式,音质高保真,通常用于专业录音和音乐制作。WMA格式&#x…

如何修复vcruntime140.dll文件?多种解决vcruntime140.dll的方法分享

在使用Windows操作系统时,经常会遇到一些错误提示,比如缺少vcruntime140.dll文件。这个文件是Visual C Redistributable Package的一部分,它负责运行C程序。如果你在运行某些软件或游戏时收到了“缺少vcruntime140.dll文件”的错误提示&#…

转 嵌入式研发人员的核心竞争力浅谈

夜深人静,万籁俱寂,正是思考的时间。这几天,我一直在想:什么才是一个嵌入式研发人员的核心竞争力? 核心竞争力是个很有诱惑力的词,它意味着你拥有别人不能简单复制的能力、经验。在职场中,竞争只…

嵌入式研发人员核心竞争力分析

什么才是一个嵌入式研发人员的核心竞争力? 核心竞争力是个很有诱惑力的词,它意味着你拥有别人不能简单复制的能力、经验。在职场中,竞争只存在于你和你的同级之间,所以你要有他们没有的核心竞争力。 一.行业 找工作时,…

嵌入式研发人员的核心竞争力浅谈 .

夜深人静,万籁俱寂,正是思考的时间。这几天,我一直在想:什么才是一个嵌入式研发人员的核心竞争力? 核心竞争力是个很有诱惑力的词,它意味着你拥有别人不能简单复制的能力、经验。在职场中,竞争只…

嵌入式研发人员的核心竞争力浅谈

这是2012年一个本科即将毕业的学生写的,这个年纪就有这样的思考还是挺有想法的。 夜深人静,万籁俱寂,正是思考的时间。这几天,我一直在想:什么才是一个嵌入式研发人员的核心竞争力? 核心竞争力是个很有诱惑…

从行业到技术,一位嵌入式er带你清晰总览嵌入式行业职业规划

找一个好工作,谈一份好薪水相信这也是大部分人的心愿,那么嵌入式行业该如何规划呢?我们今天来谈谈。 从行业到技术,一位嵌入式er带你清晰总览嵌入式行业职业规划 一。先来谈谈行业 找工作时,并不光光是找职位&#…

嵌入式行业和职业选择的看法

一、行业 找工作时,并不光光是找职位,更重要的是找行业。不同行业中同样的职位需要掌握的知识技能是不一样的,比如同样是嵌入式驱动开发工程师,消费电子可能主要是做BOOT,通信设备就更看重协议和接口的实现。这样过个…