共计 2321 个字符,预计需要花费 6 分钟才能阅读完成。
我的项目调优
作为一名工程师,我的项目调优这事,是必须得熟练掌握的事件。
在 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 开发手册(嵩山版)》最新公布,速速下载!
感觉不错,别忘了顺手点赞 + 转发哦!