记一次线上问题--SpringBoot项目开发内存占用过大
起因
由于业务的划分需要,以及需求的不断增加,我们现在已经有八个独立的服务,而每一个Springboot工程都有一个内置的Tomcat。刚开始的时候服务不是很多,服务器的内存也充足。随着服务的增加,慢慢发现内存越来越小,到最后直接飚满了。一开始不太清楚是哪里出了问题,把所有的服务停掉重启发现内存一下子就飚满了。
解决的思路
我们开发的时候在本地启服务的过程中一个很严重的资源问题就是内存占用过高,而实际上本地开发测试并没有很大的请求量,所以这是对电脑资源的一种严重浪费,单个服务在一台电脑上启动占用的内存就达到了1G到1.5G甚至更高。如果同时启动好几个服务,内存完全不够用。
解决方法
修改IDE针对每个项目的jvm参数
这里以idea为例:
1、打开Edit Configurations
在idea右上角,如图:
2、参考如下配置
左边如果是SpringCloud的话,肯定是在springboot下,如果没有,可以点击左上角的+号手动添加进去,一般启动过的项目这里都会有的。
3、关于jvm配置
设置jvm内存的参数有四个:
- -Xmx Java Heap最大值,默认值为物理内存的1/4,最佳设值应该视物理内存大小及计算机内其他内存开销而定。
- -Xms Java Heap初始值,Server端JVM最好将-Xms和-Xmx设为相同值,开发测试机JVM可以保留默认值。
- -Xmn Java Heap Young区大小,不熟悉最好保留默认值。
- -Xss 每个线程的Stack大小,不熟悉最好保留默认值;
一般用到最多的是:
- -Xms512m (堆最大大小) 设置jvm促使内存为512M,此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存
- -Xmx512m (堆默认大小) 设置jvm最大可用内存为512M
- -Xmn200m (新生代大小) 设置年轻代大小为200M。整个堆大小=年轻代大小+年老代大小+持久代大小。持久代一般固定大小为64m。所以增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8
- -Xss128k 设置每个线程的堆栈大小。JDK5.0以后每个线程堆栈大小为1M,以前每个线程堆栈大小为256K。更具应用的线程所需内存大小进行调整。在相同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右
4、Linux jvm设置
在Linux系统的服务器上面,启动各个spring cloud的微服务jar包的时候,需要在java -jar 的命令中间增加jvm的内存参数设置:-Xms64m -Xmx128m
nohup java -Xms64m -Xmx128m -jar xxx.xxxx-xxx-xxxxxx-0.0.1-SNAPSHOT.jar &
关于Jvm调优Oracle官网有一份指导说明:
Oracle官网对JVM调优的说明 大家有兴趣的可以去看看。
本文由 创作,采用 知识共享署名4.0 国际许可协议进行许可。本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名。最后编辑时间为: 2020/10/19 02:29