SpringCloud项目优化资源利用率 - Go语言中文社区

SpringCloud项目优化资源利用率


背景

在项目开发中,由于项目拆分成好多服务,启动后每个都占用不少内存;导致机器紧张,当然发布环境也是一样,在前期没有多少访问;
单个服务在一台电脑上启动占用的内存就达到了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调优的说明:
https://docs.oracle.com/middleware/11119/wls/PERFM/jvm_tuning.htm#i1146060

版权声明:本文来源CSDN,感谢博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/shenzhen_zsw/article/details/90313600
站方申明:本站部分内容来自社区用户分享,若涉及侵权,请联系站方删除。
  • 发表于 2020-06-27 22:42:55
  • 阅读 ( 959 )
  • 分类:

0 条评论

请先 登录 后评论

官方社群

GO教程

猜你喜欢