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. QT 绘制波形图、频谱图、瀑布图、星座图、眼图、语图

    说明 最近在学中频信号处理的一些东西,顺便用 QT 写了一个小工具,可以显示信号的时域波形图.幅度谱.功率谱.二次方谱.四次方谱.八次方谱.瞬时包络.瞬时频率.瞬时相位.非线性瞬时相位.瞬时幅度直方图 ...

  2. Oracle Linux切换uek内核到rhck内核解决ACFS兼容问题

    背景:协助客户做验证,客户使用的是RHEL7.6环境,我这边是OEL7.6环境,开始以为区别不大,结果acfs兼容还是遇到问题,特此记录下. 现象:asmca图形没有acfs相关内容,无法使用acfs ...

  3. 【踩坑记录】字节流数据按照string的方式读取然后按照string的方案存储,编码导致二进制数据发生变化,原理记录

    ​ 目录 问题缘由 背后原理 C#代码示例 总结 问题缘由 由于公司需求,需要读取游戏Redis数据做内外网数据迁移,没有与游戏组过多的沟通.  使用的数据类型是Hash, key是string,va ...

  4. 【HMS Core】Health Kit注册订阅后,每种设备都会通过相同的回调地址上传数据?

    ​[问题描述1] 注册订阅后,每种设备都会通过相同的回调地址上传数据? [解决方案] 一般和设备关系不大.订阅回调地址只有一个,当用户完成订阅,且用户数据在云端发生变化时,我们会向您提供的订阅地址发送 ...

  5. 「有问必答」Go如何优雅的对时间进行格式化?

    昨天 交流群 关于「Go如何优雅的对时间进行格式化?」展开了讨论: 咋搞捏? 如何在不循环的情况下,把列表数据结构体的时间修改为咱们习惯的格式,而不是UTC模式 我们要实现的效果如下: created ...

  6. Python Django 模版全解与实战

    本文首先介绍了Django模板系统的基础知识,接着探讨了如何安装和配置Django模板系统,然后深入解析了Django模板的基本结构.标签和过滤器的用法,阐述了如何在模板中展示模型数据,最后使用一个实 ...

  7. HCL实验:3.两台PC通过路由器交换机PING通

    拓扑图 路由器配置网关 PC1 ping PC2, PC3

  8. ENVI实现QUAC、简化黑暗像元、FLAASH方法的遥感影像大气校正

    本文介绍基于ENVI软件,实现对Landsat 7遥感影像加以预处理与多种不同大气校正方法的操作. 目录 1 数据导入与辐射定标 2 波段合成 3 编辑头文件 4 转换文件格式 5 QUAC快速大气校 ...

  9. jar包、war包项目部署

    部署 部署 jar包 部署 war包 部署 jar包 环境准备 JDK Tomcat Linux 环境 1.将jar文件上传至服务器 2.编写脚本 启动脚本放在跟jar 一起的路径下,如果不放在同一路 ...

  10. java学习中的一些总结

    最近java要考试了,在复习的时候就发现什么成员变量,成员函数,静态,非静态,里面的一些东西都乱七八糟的(其实是我太菜了,没有理解透彻) 我查了很多相关的资料,网上很多大佬总结的非常好 知识点一 成员 ...