问题
在开发spring cloud过程中一个很重大的资源问题就是内存占用过高,而实际上本机开发测试并没有很大的申请量,所以这是对电脑资源的一种重大的节约,甚至导致IDE卡死、解体。
一个残缺蕴含eureka,steam,sleuth,config,rabbit,oauth2等一些列spring cloud全家桶利用和其余业务相干组件组成的单个服务在12G内存电脑上启动占用的内存就达到1到1.5G。如果同时须要启动很多个服务,内存齐全不够用。
解决办法
批改IDE针对每个我的项目的jvm参数。
这里以idea为例:
1、关上Edit Configurations
Idea右上角,如图:
2.参考如下配置
右边如果是spring cloud 的话必定是在spring boot下,如果没有,能够点击左上角的+号手动增加,个别启动过的我的项目这里会有的。
对于jvm参数前面会讲。
这里要留神的是,register我的项目不须要太多资源(我这里设置128M),Gateway和config服务能够比register多一点(256M)。其它业务性服务才须要更多的资源(512M)。
请依据本人电脑配置状况调整,我的电脑是12G内存。
3.对于jvm配置
参考1:
http://blog.csdn.net/sdujava2...
设置JVM内存的参数有四个:
-Xmx Java Heap最大值,默认值为物理内存的1/4,最佳设值应该视物理内存大小及计算机内其余内存开销而定;
-Xms Java Heap初始值,Server端JVM最好将-Xms和-Xmx设为雷同值,开发测试机JVM能够保留默认值;
-Xmn Java Heap Young区大小,不相熟最好保留默认值;
-Xss 每个线程的Stack大小,不相熟最好保留默认值;
参考2:
https://www.cnblogs.com/w-wfy...
个别用到最多的是
-Xms512m 设置JVM促使内存为512m。此值能够设置与-Xmx雷同,以防止每次垃圾回收实现后JVM从新分配内存。
-Xmx512m ,设置JVM最大可用内存为512M。
-Xmn200m:设置年老代大小为200M。整个堆大小=年老代大小 + 年轻代大小 + 长久代大小。长久代个别固定大小为64m,所以增大年老代后,将会减小年轻代大小。此值对系统性能影响较大,Sun官网举荐配置为整个堆的3/8。
-Xss128k:设置每个线程的堆栈大小。JDK5.0当前每个线程堆栈大小为1M,以前每个线程堆栈大小为256K。更具利用的线程所需内存大小进行调整。在雷同物理内存下,减小这个值能生成更多的线程。然而操作系统对一个过程内的线程数还是有限度的,不能有限生成,经验值在3000~5000左右。
成果
成果很显著!
12G内存启动了14个服务和其余各种软件(idea 3个),内存占用如下图:
原文链接:https://blog.csdn.net/wanhuig...
版权申明:本文为CSDN博主「wanhuiguizong」的原创文章,遵循CC 4.0 BY-SA版权协定,转载请附上原文出处链接及本申明。
近期热文举荐:
1.1,000+ 道 Java面试题及答案整顿(2021最新版)
2.别在再满屏的 if/ else 了,试试策略模式,真香!!
3.卧槽!Java 中的 xx ≠ null 是什么新语法?
4.Spring Boot 2.5 重磅公布,光明模式太炸了!
5.《Java开发手册(嵩山版)》最新公布,速速下载!
感觉不错,别忘了顺手点赞+转发哦!