一.JVM 整体结构及内存模型
二.JVM内存参数设置
Spring Boot程序的JVM参数设置格式(Tomcat启动直接加在bin目录下catalina.sh文件里):
java ‐Xms2048M ‐Xmx2048M ‐Xmn1024M ‐Xss512K ‐XX:MetaspaceSize=256M ‐XX:MaxMetaspaceSize=256M ‐jar server.jar
堆与年轻代
-Xms:初始堆大小
-Xmx:最大堆大小
-Xmn:年轻代大小
老年代= 堆大小-年轻代大小
为了避免频繁扩容和GC释放堆内存造成的系统开销/压力 应将 Xms Xmx 两者设置为一致
元空间
关于元空间的JVM参数有两个:
- -XX:MetaspaceSize=N
设置元空间最大值, 默认是-1, 即不限制, 或者说只受限于本地内存大小。 - -XX:MaxMetaspaceSize=N
指定元空间触发Fullgc的初始阈值(元空间无固定初始大小), 以字节为单位,默认是21M,达到该值就会触发 full gc进行类型卸载, 同时收集器会对该值进行调整: 如果释放了大量的空间, 就适当降低该值; 如果释放了很少的空间, 那么在不超 过-XX:MaxMetaspaceSize(如果设置了的话) 的情况下, 适当提高该值。
由于调整元空间的大小需要Full GC,这是非常昂贵的操作,如果应用在启动的时候发生大量Full GC,通常都是由于永久代或元空间发生了大小调整,基于这种情况,一般建议在JVM参数中将MetaspaceSize和MaxMetaspaceSize设置成一样的值,并设置得比初始值要大, 对于8G物理内存的机器来说,一般我会将这两个值都设置为256M。
栈
-Xss设置越小能开启的线程数会更多,但一个线程能使用到的空间也会减小
结论
尽可能让对象都在新生代里分配和回收
尽量别让太多对象频繁进入老年代,避免频繁对老年代进行垃圾回收,同时给系统充足的内存大小,避免新生代频繁的进行垃圾回收。