Tomcat(四)

Tomcat优化

JVM参数

编辑 TOMCAT_HOME/bin/catalina.sh 文件,找到 JAVA_OPTS 变量,并添加 JVM 参数。

  • -Xms:初始堆内存大小。
  • -Xmx:最大堆内存大小。
  • -XX:PermSize:永久代初始大小(Java 8 及以上版本使用元空间)。
  • -XX:MaxPermSize:永久代最大大小(Java 8 及以上版本使用元空间)。
  • -XX:MetaspaceSize:元空间初始大小(Java 8 及以上版本)。
  • -XX:MaxMetaspaceSize:元空间最大大小(Java 8 及以上版本)。
  • -XX:+UseG1GC:使用 G1 垃圾回收器。适合大内存应用。
  • -Xss:每个线程的栈大小。
bash 复制代码
# 修改或添加以下行
JAVA_OPTS="-Xms1024m -Xmx1024m -XX:PermSize=512m -XX:MaxPermSize=512m -XX:+UseG1GC -Xss256k"

连接器优化

编辑 server.xml 。

  • protocol="org.apache.coyote.http11.Http11NioProtocol":使用 NIO 连接器,提高性能。
  • maxThreads:设置最大线程数,根据服务器性能调整。
  • acceptCount:设置接受队列的大小,当所有线程都忙时,新连接将被放入队列中等待。
bash 复制代码
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
           acceptCount="100"
           maxThreads="500"
           connectionTimeout="20000"
           redirectPort="8443" />

调整线程池

编辑 server.xml

  • maxThreads:最大线程数。
  • minSpareThreads:最小空闲线程数。
  • maxIdleTime:线程的最大空闲时间。
bash 复制代码
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
          maxThreads="500" minSpareThreads="50"
          maxIdleTime="60000" />

启用压缩

编辑 server.xml

  • compression:启用压缩。
  • compressionMinSize:最小压缩大小。
  • noCompressionUserAgents:不压缩的用户代理。
  • compressableMimeType:可压缩的 MIME 类型。
bash 复制代码
<Connector port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol"
           compression="on"
           compressionMinSize="2048"
           noCompressionUserAgents="Gozilla,Travelscape"
           compressableMimeType="text/html,text/xml,text/plain,application/json" />
相关推荐
程序员清风1 分钟前
猿辅导二面:线上出现的OOM是如何排查的?
java·后端·面试
牛奶咖啡134 分钟前
shell脚本编程(七)
linux·shell脚本编程·列表for循环·列表for循环的多种示例·for循环的break用法·for循环continue用法·c语言型for循环
yaoxin5211236 分钟前
291. Java Stream API - 从正则表达式创建 Stream
java·开发语言
噎住佩奇8 分钟前
正则表达式(Regex)入门
运维·正则表达式
BHXDML10 分钟前
Java 设计模式详解
java·开发语言·设计模式
BD_Marathon11 分钟前
MyBatis核心配置文件之mappers
java·数据库·mybatis
余瑜鱼鱼鱼17 分钟前
Java数据结构:从入门到精通(十三)
java·开发语言
运维行者_26 分钟前
远程办公场景 NFA:从网络嗅探与局域网流量监控软件排查团队网络卡顿问题
运维·服务器·开发语言·网络·自动化·php
没有bug.的程序员33 分钟前
Java内存模型(JMM)深度解析:从 volatile 到 happens-before 的底层机制
java·开发语言·并发编程·volatile·内存模型·jmm·happens-before