1、关于JVM配置:
-Xmx 设置堆(Java Heap)最大值,默认值为物理内存的1/4,最佳设值应该视物理内存大小及计算机内其他内存开销而定。
-Xms 设置初始堆(Java Heap)初始值,Server端JVM最好将-Xms和-Xmx设为相同值,开发测试机JVM可以保留默认值。
-Xmn 设置年轻代(Java Heap Young)区大小,在整个堆内存大小确定的情况下,增大年轻代将会减小老年代,反之亦然。不熟悉最好保留默认值。
-Xss 每个线程的栈(Stack)大小,不熟悉最好保留默认值;
-XX:NewSize=1024m 设置年轻代初始值
-XX:MaxNewSize=1024m 设置年轻代最大值
-XX:PermSize=256m 设置持久代初始值
-XX:MaxPermSize=256m 设置持久代初始值
-XX:NewRatio=4 设置年轻代(包括一个Eden区和两个Survivor区)和年老代的比值。
-XX:SurivivorRatio=4 设置Survivor区和Eden区的比值。
-XX:MaxTenuringThreshold=7 表示一个对象如果在Survivor区(救助空间)移动了7次还没有被垃圾回收就进入年老代。
一般用到最多的是:
-Xms512m (堆最大大小) 设置jvm促使内存为512M,此值可以设置与-Xmx相同,以避免每次垃圾回收完成后JVM重新分配内存
-Xmx512m (堆默认大小) 设置jvm最大可用内存为512M
-Xmn200m (新生代大小) 设置年轻代大小为200M。整个堆大小=年轻代大小+年老代大小+持久代大小。持久代一般固定大小为64m。所以增大年轻代后,将会减小年老代大小。此值对系统性能影响较大,Sun官方推荐配置为整个堆的3/8
-Xss128k 设置每个线程的堆栈大小。JDK5.0以后每个线程堆栈大小为1M,以前每个线程堆栈大小为256K。更具应用的线程所需内存大小进行调整。在相同物理内存下,减小这个值能生成更多的线程。但是操作系统对一个进程内的线程数还是有限制的,不能无限生成,经验值在3000~5000左右
2、Linux JVM设置:
在Linux系统的服务器上面,启动各个spring cloud的微服务jar包的时候,需要在java -jar 的命令中间增加jvm的内存参数设置:-Xms64m -Xmx128m
nohup java -Xms64m -Xmx128m -jar xx-xxxxxx-0.0.1.jar &
nohup java -Xms64m -Xmx128m -jar xx-xxxxxx-0.0.1.jar > xx-xxxxxx-0.0.1.log &