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" />
相关推荐
欢喜躲在眉梢里4 分钟前
CANN 异构计算架构实操指南:从环境部署到 AI 任务加速全流程
运维·服务器·人工智能·ai·架构·计算
IUGEI7 分钟前
synchronized的工作机制是怎样的?深入解析synchronized底层原理
java·开发语言·后端·c#
q***136112 分钟前
Windows操作系统部署Tomcat详细讲解
java·windows·tomcat
z***I39412 分钟前
Java桌面应用案例
java·开发语言
weixin_5377658026 分钟前
【容器技术】虚拟化原理与Docker详解
运维·docker·容器
胡斌附体30 分钟前
docker健康检查使用
运维·docker·依赖·健康检查
r***123832 分钟前
SpringBoot最佳实践之 - 使用AOP记录操作日志
java·spring boot·后端
间彧36 分钟前
Java进程内存深度解析:从JVM组件内存到RSS的全面视角
java
间彧43 分钟前
对比GraalVM Native Image与传统JVM,在内存管理方面各自适合哪些具体业务场景?
java
云飞云共享云桌面43 分钟前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑