1、工具

jdk自带的工具位置:



找到窗口->应用程序

2、问题和方式

在SpringBoot项目中,调优主要通过配置文件和配置JVM的参数的方式进行。

2.1 springboot修改配置文件调优

关于修改配置文件application.properties。

https://docs.spring.io/spring-boot/docs/current/reference/html/common-application-properties.html#common-application-properties

其中比较重要的配置

server.tomcat.max-connections=0 #服务器在任何给定时间接受和处理的最大连接数
time.server.tomcat.max-http-header-size=0 # HTTP消息的最大大小(以字节为单位)
header.server.tomcat.max-http-post-size=0 # HTTP头部的最大大小(以字节为单位)
content.server.tomcat.max-threads=0 # 最大工作数
threads.server.tomcat.min-spare-threads=0 #最小工作线程数

2.2jvm调优

jvm官放调优文档

https://docs.oracle.com/middleware/11119/wls/PERFM/jvm_tuning.htm#i1146060

实战:

1、未设置JVM参数的情况

有一个项目,默认情况下,没有设置任何Jvm参数。下面我来启动看一下



看一下堆栈分配:很明显默认的最大堆 内存分配了8个G。很明显的不合理



2、下面我们来设置下Jvm参数,例如要配置JVM这么一大段参数:

 -XX:MetaspaceSize=128m  -XX:MaxMetaspaceSize=128m  -Xms1024m -Xmx1024m -Xmn256m  -Xss256k -XX:SurvivorRatio=8 -XX:+UseConcMarkSweepGC

方式一:

如果你用的是IDEA等开发工具,来启动运行项目,那么要调试JDK就方便太多了。只需要将参数值设置到VM options中即可。



设置成功,我的GC日志和堆栈分配都已经OK了。GC日志:



堆栈分配:



方式二:

适用于在项目部署后,在启动的时候,采用脚本或者命令行运行的时候设置。

先在项目路径下,给项目打包:

mvn clean
mvn package -Dmaven.test.skip=true



执行启动设置Jvm参数的操作

java -jar -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m -Xms1024m -Xmx1024m -Xmn256m -Xss256k -XX:SurvivorRatio=8 -XX:+UseConcMarkSweepGC newframe-1.0.0.jar

堆栈都是按照启动时候,设置的Jvm参数启动的。

3、参数说明

点击查看代码
-XX:MetaspaceSize=128m (元空间默认大小)
-XX:MaxMetaspaceSize=128m (元空间最大大小)
-Xms1024m(设置堆的初始值,一般设置成和Xmx一样来避免动态扩容)
-Xmx1024m(堆的最大值,一般未操作系统的2/3大小)
-Xmn256m(新生代大小,默认新生代占堆大小的1/3。高并发快消亡场景可适当加大这个区域。对半,或者更多,都是可以的。但是在G1下,就不用再设置这个值了,它会自动调整)
-Xss256k (-Xss 设置栈的大小,默认为1M,已经足够用了)
-XX:SurvivorRatio=8(新生代分区比例8:2 表示伊甸区和幸存区的比例)
-XX:+UseConcMarkSweepGC(要指定JVM使用的垃圾回收器。尽量不要靠默认值去保证,要显式的指定一个。)
-XX:+PrintGCDetails(打印详细的GC日志)

注意:

JDK8之后把-XX:PermSize 和 -XX:MaxPermGen移除了,取而代之的是

-XX:MetaspaceSize=128m (元空间默认大小)

-XX:MaxMetaspaceSize=128m (元空间最大大小)

JDK 8开始把类的元数据放到本地化的堆内存(native heap)中,这一块区域就叫Metaspace,中文名叫元空间。

使用本地化的内存有什么好处呢?最直接的表现就是java.lang.OutOfMemoryError: PermGen 空间问题将不复存在,因为默认的类的元数据分配只受本地内存大小的限制,也就是说本地内存剩余多少,理论上Metaspace就可以有多大(貌似容量还与操作系统的虚拟内存有关?这里不太清楚),这解决了空间不足的问题。

不过,让Metaspace变得无限大显然是不现实的,因此我们也要限制Metaspace的大小:使用-XX:MaxMetaspaceSize参数来指定Metaspace区域的大小。JVM默认在运行时根据需要动态地设置MaxMetaspaceSize的大小。

垃圾回收机制原理:

https://blog.csdn.net/qq_41946216/article/details/131201057

Java 提供了多种不同的垃圾收集器,每个垃圾收集器都有其独特的优势和适用场景。以下是几种常见的垃圾收集器及其主要特点的比较:

Serial 垃圾收集器:
单线程收集器,适用于小型或简单的应用程序。
使用复制算法进行新生代垃圾收集,产生较短的停顿时间。
适合于客户端应用或调试环境。 Parallel 垃圾收集器:
多线程收集器,在新生代和老年代均可使用。
采用复制算法进行新生代垃圾收集,标记-清除-整理算法进行老年代垃圾收集。
可以通过增加线程数量来提高吞吐量。
适合于数据处理或批量作业等需要高吞吐量的场景。 CMS (Concurrent Mark-Sweep) 垃圾收集器:
并发收集器,在老年代进行垃圾收集时,尽可能减少停顿时间。
使用标记-清除算法进行垃圾收集,但不会进行内存整理。
具有较低的停顿时间,适合对响应时间有要求的应用程序。
适合于中型至大型的 Web 应用。 G1 (Garbage-First) 垃圾收集器:
并发收集器,面向大堆内存,能够处理复杂的内存布局。
将堆内存划分为多个区域,采用复制算法进行收集。
可以并发地进行垃圾收集,减少停顿时间。
高度可预测的暂停时间,适合于需要低停顿时间的应用程序。
以上只是一些常见的垃圾收集器,Java 还提供了其他垃圾收集器如 ZGC 和 Shenandoah,它们针对特定的场景和需求提供了更高级别的性能和吞吐量优化。 选择适当的垃圾收集器取决于应用程序的特点、硬件环境和性能需求。在进行选择时,建议进行实际测试和基准测试,以确定最适合的垃圾收集器。

springboot、jvm调优(设置运行的参数)的更多相关文章

  1. jmeter --JVM调优设置

    JMeter用户可根据运行的计算机配置,来适当调整JMeter.bat中的JVM调优设置,如下所示: set HEAP=-Xms512m -Xmx512m set NEW=-XX:NewSize=12 ...

  2. JVM调优(一)——参数查询和问题排查

    JVM的参数类型 标准参数 -help -server -client -version -showversion -cp -classpath X参数 -Xint: 解释执行 -Xcomp:第一次使 ...

  3. JVM调优之Tomcat启动参数配置及详解

    开发项目中会遇到Tomcat内存溢出(java.lang.OutOfMemoryError: PermGen space)的问题,通过查找资料找到是通过设置Tomcat 启动堆空间大小.年轻代大小.每 ...

  4. JVM调优——之CMS 常见参数解析

    最近在学习使用CMS这个GC,这里记录下常用的参数. 1. UseCMSCompactAtFullCollection 与 CMSFullGCsBeforeCompaction 有一点需要注意的是:C ...

  5. 美团面试:熟悉哪些JVM调优参数?

    本文已经收录到Github仓库,该仓库包含计算机基础.Java基础.多线程.JVM.数据库.Redis.Spring.Mybatis.SpringMVC.SpringBoot.分布式.微服务.设计模式 ...

  6. jvm调优的分类

    本文部分内容出自https://blog.csdn.net/yang_net/article/details/5830820 调优步骤: 衡量系统现状. 设定调优目标. 寻找性能瓶颈. 性能调优. 衡 ...

  7. JVM调优(二)经验参数设置

    调优设置具体解析 堆大小设置 JVM 中最大堆大小有三方面限制:相关操作系统的数据模型(32-bt还是64-bit)限制:系统的可用虚拟内存限制:系统的可用物理内存限制.32位系统下,一般限制在1.5 ...

  8. JVM调优及参数设置

    (1)参数 -Xms:初始堆大小 -Xmx :最大堆大小 此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存 -Xmn :年轻代大小 整个堆大小=年轻代大小 + 年老代大小 + 持 ...

  9. 生产环境下JVM调优参数的设置实例

    JVM基础:生产环境参数实例及分析 原始配置: -Xms128m -Xmx128m -XX:NewSize=64m -XX:PermSize=64m -XX:+UseConcMarkSweepGC - ...

  10. SpringBoot项目优化和Jvm调优(转)

    原文:https://blog.csdn.net/wd2014610/article/details/82182617 项目调优作为一名工程师,项目调优这事,是必须得熟练掌握的事情. 在SpringB ...

随机推荐

  1. Java实现Kafka生产者和消费者的示例

    Kafka简介 Kafka是由Apache软件基金会开发的一个开源流处理平台,由Scala和Java编写.Kafka的目标是为处理实时数据提供一个统一.高吞吐.低延迟的平台. 文章持续更新,微信搜索「 ...

  2. tar 命令压缩时报错 Removing leading `/' from member names 解决方法

    原文:https://www.cnblogs.com/operationhome/p/9802554.html 在使用tar命令进行压缩打包的时候我们常常会遇到下面的错误.虽然它不会影响我们最后的压缩 ...

  3. 如何解决PyCharm中运行不了python代码的问题

    一.问题分析 一般是新手小白才会出现这个问题.刚入门python或者Web自动化测试的集美们很多都会选择使用PyCharm来运行python,但是下载安装完PyCharm后,新建了一个python项目 ...

  4. CANoe_系统变量的创建过程

    在Canoe中创建系统变量,可以用于定义和管理与CAN网络通信相关的参数和配置.遵循以下步骤: 1.打开Canoe 启动Canoe软件. 2.打开项目 在Canoe的菜单栏中,选择"File ...

  5. Windows11右键菜单修改为Win10模式的方法

    Windows11右键菜单修改为Win10模式的方法 自述: 更新win11后看着鼠标右键的菜单有些不太舒服,索性就改回了win10的右键菜单的样式 , 下面开始进行操作 第一步 首先以管理员方式打开 ...

  6. 统信UOS国产服务器操作系统(UOS Server 20-1060e)安装使用体验

    总体来说,UOS系统的安装还是很简明的.需要注意的是后期的驱动安装和其他各方面的使用细节. 以下是具体安装过程:(感谢统信软件河北团队的大力支持.) 特别感谢统信的郭赞.喵喵喵.Zero等各位大神的帮 ...

  7. CAN转PROFINET协议网关 JM-PN-CAN

        1 产品功能 捷米特JM-PN-CAN 是自主研发的一款 PROFINET 从站功能的通讯网关.主要功能是将各种 CAN 设备接入到 PROFINET 网络中. 捷米特JM-PN-CAN连接到 ...

  8. 基于JavaFX的扫雷游戏实现(四)——排行榜

      这期看标题已经能猜到了,主要讲的是成绩排行功能,还有对应的文件读写.那么废话不多说,让我们有请今天的主角...的设计稿:   那么主角是何方神圣呢?当然是图中的大框框--TableView.关于这 ...

  9. 解决github网站打不开

    方法一(此方法无效则选 方法二) 发现github经常打不开无法访问,最近尝试了下改host发现效果挺好,方法如下(windows电脑): 进入站长工具网站的域名解析网址:http://tool.ch ...

  10. Lens Shading成因及相关

    一个监控摄像头光学处理包含以下几个部分:镜头(Lens)(定变焦镜头).红外截止滤波片(IR-cut filter)(红外截止滤光片和蓝玻璃滤光片为主).图像传感器(Image Sensor)和印制电 ...