乐趣区

关于java:Spring-Cloud-开发内存占用过高咋解决

问题

在开发 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 开发手册(嵩山版)》最新公布,速速下载!

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

退出移动版