由浅入深理解JVM 内存模型以及相关优化策略

由浅入深理解JVM 内存模型以及相关优化策略
JDK体系结构
由浅入深理解JVM 内存模型以及相关优化策略_第1张图片
Java 语言的强大不仅仅表现在其内部实现的垃圾回收的机制,更强大的还表现在其强大的跨平台(操作系统)特性,其内部(JVM)已经实现了java 应用在不同操作系统底层硬件指令的适配
由浅入深理解JVM 内存模型以及相关优化策略_第2张图片

JVM整体结构及内存模型
由浅入深理解JVM 内存模型以及相关优化策略_第3张图片

同时,java 还提供了对各区域大小调整的参数设置 ,一般不需要去修改,就用其默认的就行了
如果想了解各大参数的意思,可以使用Dos 命令使用cmd 然后 输入Java -X
由浅入深理解JVM 内存模型以及相关优化策略_第4张图片JVM参数设置:
由浅入深理解JVM 内存模型以及相关优化策略_第5张图片
Spring Boot程序的JVM参数设置格式(Tomcat启动直接加在bin目录下catalina.sh文件里):
java -Xms2048M -Xmx2048M -Xmn1024M -Xss512K -XX:MetaspaceSize=256M -XX:MaxMetaspaceSize=256M -jar demo-xxx.jar

-Xss:每个线程的栈大小
-Xms:初始堆大小,默认物理内存的1/64
-Xmx:最大堆大小,默认物理内存的1/4
-Xmn:新生代大小
-XX:NewSize:设置新生代初始大小
-XX:NewRatio:默认2表示新生代占年老代的1/2,占整个堆内存的1/3。
-XX:SurvivorRatio:默认8表示一个survivor区占用1/8的Eden内存,即1/10的新生代内存。
关于元空间的JVM参数有两个:-XX:MetaspaceSize=N和 -XX:MaxMetaspaceSize=N
-XX:MaxMetaspaceSize: 设置元空间最大值, 默认是-1, 即不限制, 或者说只受限于本地内存大小。
-XX:MetaspaceSize: 指定元空间触发Fullgc的初始阈值(元空间无固定初始大小), 以字节为单位,默认是21M,达到该值就会触发full gc进行类型卸载, 同时收集器会对该值进行调整: 如果释放了大量的空间, 就适当降低该值; 如果释放了很少的空间, 那么在不超过-XX:MaxMetaspaceSize(如果设置了的话) 的情况下, 适当提高该值。这个跟早期jdk版本的-XX:PermSize参数意思不一样,-XX:PermSize代表永久代的初始容量。
由于调整元空间的大小需要Full GC,这是非常昂贵的操作,如果应用在启动的时候发生大量Full GC,通常都是由于永久代或元空间发生了大小调整,基于这种情况,一般建议在JVM参数中将MetaspaceSize和MaxMetaspaceSize设置成一样的值,并设置得比初始值要大,对于8G物理内存的机器来说,一般我会将这两个值都设置为256M。

计算相关堆内存可以使用如图代码获取或者使用JDK 自带的工具jvisualvm
查看
由浅入深理解JVM 内存模型以及相关优化策略_第6张图片
由浅入深理解JVM 内存模型以及相关优化策略_第7张图片
结论:
-Xss设置越小count值越小,说明一个线程栈里能分配的栈帧就越少,但是对JVM整体来说能开启的线程数会更多
JVM优化建议:尽可能让对象都在新生代里分配和回收,尽量别让太多对象频繁进入老年代,避免频繁对老年代进行垃圾回收,同时给系统充足的内存大小,避免新生代频繁的进行垃圾回收。减少full gc 的发生次数,让大部分对象尽可能在年轻代被回收,这就是为什么JVM堆内存在优化是要京可能设置大一点的原因,就是为了让对象尽可能的在年轻代被回收!

你可能感兴趣的:(技术,java,jvm)