乐趣区

关于java:Spring-Boot-项目优化和-JVM-调优亲测真实有效

我的项目调优

作为一名工程师,我的项目调优这事,是必须得熟练掌握的事件。

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

一、批改配置文件

对于批改配置文件 application.properties。

https://docs.spring.io/spring…

其中比拟重要的有:

server.tomcat.max-connections=0 # Maximum number of connections that the server accepts and processes at any given time.
server.tomcat.max-http-header-size=0 # Maximum size, in bytes, of the HTTP message header.
server.tomcat.max-http-post-size=0 # Maximum size, in bytes, of the HTTP post content.
server.tomcat.max-threads=0 # Maximum number of worker threads.
server.tomcat.min-spare-threads=0 # Minimum number of worker threads.

二、Jvm 调优

对于 Jvm 调优 Oracle 官网有一份领导阐明:

https://docs.oracle.com/middl…

三、Jvm 调优实战

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

打包实现后进入可运行 Jar 包的门路下:

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

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

这个时候,你再看监控,你就会发现,曾经是 Ok 的了。

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

对于这些设置的 JVM 参数是什么意思,请参考第二步中的 oracle 官网给出的调优文档。

我在这边简略说一下:

-XX:MetaspaceSize=128m(元空间默认大小)-XX:MaxMetaspaceSize=128m(元空间最大大小)-Xms1024m(堆最大大小)-Xmx1024m(堆默认大小)-Xmn256m(新生代大小)-Xss256k(棧最大深度大小)-XX:SurvivorRatio=8(新生代分区比例 8:2)-XX:+UseConcMarkSweepGC(指定应用的垃圾收集器,这里应用 CMS 收集器)-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/wd20146…

版权申明:本文为 CSDN 博主「向小凯同学学习」的原创文章,遵循 CC 4.0 BY-SA 版权协定,转载请附上原文出处链接及本申明。

近期热文举荐:

1.1,000+ 道 Java 面试题及答案整顿(2021 最新版)

2. 别在再满屏的 if/ else 了,试试策略模式,真香!!

3. 卧槽!Java 中的 xx ≠ null 是什么新语法?

4.Spring Boot 2.5 重磅公布,光明模式太炸了!

5.《Java 开发手册(嵩山版)》最新公布,速速下载!

感觉不错,别忘了顺手点赞 + 转发哦!

退出移动版