这年头还有问Tomcat调优和JVM参数优化的,你还不知道怎么回答么?那么你一定需要看看这篇文章

简介: 前几天阿粉的一个小学弟在咨询阿粉面试的时候怎么还会问到关于Tomcat调优和JVM优化,我听完这个的时候,当时就想说,问这个不是应该的么?那么下面阿粉就给大家好好的掰扯掰扯这个Tomcat优化和 JVM 参数优化的事情

前几天阿粉的一个小学弟在咨询阿粉面试的时候怎么还会问到关于Tomcat调优和JVM优化,我听完这个的时候,当时就想说,问这个不是应该的么?那么下面阿粉就给大家好好的掰扯掰扯这个Tomcat优化和 JVM 参数优化的事情

Tomcat


46.jpg

关于Tomcat是什么东西,相信大家做开发的,肯定是一点也不陌生,服务器,Web应用服务器,一种轻量级的应用服务器,在中小型系统和并发访问用户不是很多的场合下被普遍使用,是开发和调试JSP 程序的首选。

而我们在日常的开发中,可能很大一部分我们只是知道怎么使用Tomcat服务器,但是却不知道怎么去调整Tomcat里面的各种配置参数,让Tomcat能够更好的运行,那么就听阿粉来给大家介绍把。

配置文件修改优化

Tomcat在Windows下一般的目录都是我们下载解压出来的目录也就是${TOMCAT_HOME},就像这个样子 D:\develop\tomcat\apache-tomcat-7.0.88,而他的配置文件就是conf下的server.xml文件,而我们需要调优的肯定也是这个文件里面的内容。

我们就先从 Connector 来进行分析:

Connector :连接器,负责接收客户的请求,以及向客户端回送响应的消息

而我们对 Connector 优化,其实优化的就是我们在访问请求时候的并发能力,而往往并发也是我们在工作中很多时候需要去考虑的问题,而我们在这个连接器里面可以配置什么内容呢?

<Connector executor="tomcatThreadPool"
               port="8080" protocol="HTTP/1.1"
               connectionTimeout="20000"
               redirectPort="8443" />

我们最常用的就是在里面配置一个URL的统一编码格式比如说我们在里面配置一个 UTF-8 的编码格式。

URIEncoding :URIEncoding = UTF-8

executor : 指定这个连接器所使用的执行器(线程池)

connectionTimeout :连接超时时间

maxThreads :客户请求最大线程数

minSpareThreads :Tomcat初始化时创建的线程数,一直会运行的线程

maxSpareThreads :Tomcat连接器的最大空闲线程数

minProcessors :服务器创建时的最小处理线程数

maxProcessors :服务器同时最大处理线程数

enableLookups :若设为true, 则支持域名解析,可把 ip 地址解析为主机名,而为了减少性能的消耗的话,我们就有时候会关闭它

redirectPort :在需要基于安全通道的场合,把客户请求转发到基于SSL 的 redirectPort 端口

acceptAccount :监听端口队列最大数,满了之后客户请求会被拒绝(不能小于maxSpareThreads )

而我们一般最常搭配的,却是 URIEncoding 而很少的去改其他的配置,但是在面试中,肯定不会说让你去优化编码格式把,而我们修改的一定是其他的关于最大处理线程数,域名解析啦,

而我们在最终的配置就不再是上面的代码了,而变成了优化之后的:

<Connector port="8080"
        protocol="HTTP/1.1" 
        connectionTimeout="20000" 超时时间,毫秒
        redirectPort="443" 
        maxThreads="3000" 最大线程数
        minSpareThreads="20" 最小空闲线程数,这里是一直会运行的线程
        acceptCount="1000" 监听端口队列数
        enableLookups="false" 关闭dns解析,减少性能损耗
        server="None"               
        URIEncoding="UTF-8"   
      />

NIO和BIO还有 NIO2

其实关于 NIO 和 BIO 和 AIO 阿粉在之前已经完全都说过了,同步阻塞 IO 就是 BIO ,而同步非阻塞IO和异步阻塞IO 就是 NIO ,而异步非阻塞IO就是 AIO 啦,

BIO :同步阻塞IO

47.jpg

NIO :同步非阻塞IO和异步阻塞IO

AIO :这种异步非阻塞 IO 是我们最需要注意的,是从 JDK7 及其以上才会支持的。

话不多说,直接上如何修改,

<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443"/>
<Connector connectionTimeout="20000" port="8080" protocol="org.apache.coyote.http11.Http11NioProtocol" redirectPort="8443"/>

网上有人说,从 Tomcat8 以上就是 NIO 模式了,但是实际情况好像是没有,还是需要自己手动去换成 NIO 模式。

关于 Tomcat的优化,阿粉就不再给大家叙述了,给大家再来说说这个关于 JVM 的优化。

JVM

阿粉最开始写文章的时候,就是首先从 JVM 写起来的,大家可以搜索一下曾经阿粉写的关于 JVM 的内容,里面有对 JVM 的完整的介绍,对 FullGC ,YGC 等垃圾收集方式,都做过介绍,这里阿粉只给大家介绍怎么去通过修改 Tomcat 的配置,来达到,我们对 JVM 的优化。

大家都知道,正确的选择不同的 GC 策略,调整 JVM、GC 的参数,可以极大的减少由于 GC 工作,而却这样会大大的提高我们程序的运行效率。

目录还是那个目录,Tomcat 的根目录下的 bin 目录,catalina.bat ,Linux的话,去修改.sh 的文件即可。

找到 JAVA_OPTS 而他就是用来设置 JVM 相关运行参数的变量的,在这里阿粉也给大家说一下关于 JVM 的参数属性,不然不能直接瞎改吧,容易出事。

-Xms :初始堆大小 物理内存的1/64(<1GB)

-Xmx :最大堆大小 物理内存的1/4(<1GB)

-Xmn :年轻代大小(1.4or lator)  注意的是这个 ,整个堆大小=年轻代大小 + 年老代大小 + 持久代大小.

-XX:NewSize :设置年轻代大小(for 1.3/1.4)

-XX:MaxNewSize :年轻代最大值(for 1.3/1.4)

-XX:PermSize :设置持久代(perm gen)初始值 物理内存的1/64

-XX:MaxPermSize :设置持久代最大值 物理内存的1/4

-Xss :每个线程的堆栈大小

-XX:NewRatio :年轻代(包括Eden和两个Survivor区)与年老代的比值(除去持久代)

-XX:+AggressiveOpts :加快编译

-XX:+UseBiasedLocking :锁机制的性能改善

-XX:+DisableExplicitGC :关闭System.gc()

-XX:+UseParNewGC :设置年轻代为并行收集

-XX:+UseConcMarkSweepGC :使用CMS内存收集

-XX:MaxTenuringThreshold :垃圾最大年龄

-XX+UseCMSCompactAtFullCollection :在FULL GC的时候, 对年老代的压缩

-XX:LargePageSizeInBytes :内存页的大小不可设置过大, 会影响Perm的大小

-XX:+UseFastAccessorMethods :原始类型的快速优化

-XX:+UseCMSInitiatingOccupancyOnly :使用手动定义初始化定义开始CMS收集

而这些内容就是需要你去自己手动去挑选一些合适的自己去配置上去,而不是一股脑的复制上去,不然适得其反就不好了。

给阿粉点个在看吧?

相关文章
|
2月前
|
缓存 Java 应用服务中间件
Spring Boot配置优化:Tomcat+数据库+缓存+日志,全场景教程
本文详解Spring Boot十大核心配置优化技巧,涵盖Tomcat连接池、数据库连接池、Jackson时区、日志管理、缓存策略、异步线程池等关键配置,结合代码示例与通俗解释,助你轻松掌握高并发场景下的性能调优方法,适用于实际项目落地。
466 5
|
12月前
|
监控 Java 编译器
Java虚拟机调优指南####
本文深入探讨了Java虚拟机(JVM)调优的精髓,从内存管理、垃圾回收到性能监控等多个维度出发,为开发者提供了一系列实用的调优策略。通过优化配置与参数调整,旨在帮助读者提升Java应用的运行效率和稳定性,确保其在高并发、大数据量场景下依然能够保持高效运作。 ####
269 58
|
11月前
|
监控 架构师 Java
Java虚拟机调优的艺术:从入门到精通####
本文作为一篇深入浅出的技术指南,旨在为Java开发者揭示JVM调优的神秘面纱,通过剖析其背后的原理、分享实战经验与最佳实践,引领读者踏上从调优新手到高手的进阶之路。不同于传统的摘要概述,本文将以一场虚拟的对话形式,模拟一位经验丰富的架构师向初学者传授JVM调优的心法,激发学习兴趣,同时概括性地介绍文章将探讨的核心议题——性能监控、垃圾回收优化、内存管理及常见问题解决策略。 ####
|
12月前
|
监控 Java 测试技术
Elasticsearch集群JVM调优垃圾回收器的选择
Elasticsearch集群JVM调优垃圾回收器的选择
389 1
|
12月前
|
监控 Java 编译器
Java虚拟机调优实战指南####
本文深入探讨了Java虚拟机(JVM)的调优策略,旨在帮助开发者和系统管理员通过具体、实用的技巧提升Java应用的性能与稳定性。不同于传统摘要的概括性描述,本文摘要将直接列出五大核心调优要点,为读者提供快速预览: 1. **初始堆内存设置**:合理配置-Xms和-Xmx参数,避免频繁的内存分配与回收。 2. **垃圾收集器选择**:根据应用特性选择合适的GC策略,如G1 GC、ZGC等。 3. **线程优化**:调整线程栈大小及并发线程数,平衡资源利用率与响应速度。 4. **JIT编译器优化**:利用-XX:CompileThreshold等参数优化即时编译性能。 5. **监控与诊断工
|
6月前
|
Arthas 存储 算法
深入理解JVM,包含字节码文件,内存结构,垃圾回收,类的声明周期,类加载器
JVM全称是Java Virtual Machine-Java虚拟机JVM作用:本质上是一个运行在计算机上的程序,职责是运行Java字节码文件,编译为机器码交由计算机运行类的生命周期概述:类的生命周期描述了一个类加载,使用,卸载的整个过类的生命周期阶段:类的声明周期主要分为五个阶段:加载->连接->初始化->使用->卸载,其中连接中分为三个小阶段验证->准备->解析类加载器的定义:JVM提供类加载器给Java程序去获取类和接口字节码数据类加载器的作用:类加载器接受字节码文件。
583 55
|
23天前
|
存储 缓存 Java
我们来说一说 JVM 的内存模型
我是小假 期待与你的下一次相遇 ~
161 4
|
30天前
|
存储 缓存 算法
深入理解JVM《JVM内存区域详解 - 世界的基石》
Java代码从编译到执行需经javac编译为.class字节码,再由JVM加载运行。JVM内存分为线程私有(程序计数器、虚拟机栈、本地方法栈)和线程共享(堆、方法区)区域,其中堆是GC主战场,方法区在JDK 8+演变为使用本地内存的元空间,直接内存则用于提升NIO性能,但可能引发OOM。
|
7月前
|
Arthas 监控 Java
Arthas memory(查看 JVM 内存信息)
Arthas memory(查看 JVM 内存信息)
555 6