91名师指路-头部
91名师指路

面试题(四)你工作中常用的jvm参数有哪些?

由于某些原因,现在不支持支付宝支付,如需要购买源码请加博主微信进行购买,微信号:13248254750

jvm常用参数:

(1) -Xms。初始堆内存大小,默认为物理内存1/64。等价于 -XX:InitialHeapSize。

(2) -Xmx。最大堆内存大小,默认为物理内存1/4。等价于 -XX:MaxHeapSize。

(3) -Xss。设置单个线程的栈大小,一般默认为512K~1024K。等价于 -XX:ThreadStackSize。

(4) -Xmn。设置年轻代大小。

(5) -XX:MetaspaceSize。设置元空间大小。元空间的本质和永久代类似,都是对jvm规范中方法区的实现,不过元空间与永久代之间最大的区别在于:元空间并不在虚拟机中,而是使用本地内存。因此默认情况下,元空间的大小仅受本地内存限制。

(6) -XX:+PrintGCDetails。输出详细GC收集日志信息。

(7) -XX:SurvivoRatio。设置新生代中eden和s0/s1空间的比例,默认-XX:SurvivoRatio=8,Eden:s0:s1=8:1:1

(8) -XX:NewRatio。配置年轻代与老年代在堆结构的占比,默认-XX:NewRatio=2,新生代占1,老年代占2,年轻代占整个堆的1/3,也就是说新生代和老年代的比例为1:2

(9) -XX:MaxTenuringThreshold。设置垃圾最大年龄。范围为0 - 15,默认为15,如果设置为0的话,则年轻带对象不经过Survivor区,直接进入年老代。对于年老代比较多的应用,可以提高效率。如果将此值设置为一个较大值,则年轻代对象会在Survivor区进行多次复制,这样可以增加对象再年轻代的存活时间,增加在年轻代即被回收的概论。


一:-Xss参数说明,我们启动一个程序,代码如下

package com.mszl.gc;
/**
* 功能:演示jvm默认MetaspaceSize大小
* 备注:更多资料请访问 http://www.91mszl.com
* @author bobo teacher
*/
public class GcDemo1 {

public static void main(String[] args) {
System.out.println(" hello http://www.91mszl.com");
try {
Thread.sleep(100000000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}


}

执行结果

C:\Windows\system32>jps -l
4608
5648
3864 com.mszl.gc.GcDemo1
2348 sun.tools.jps.Jps

C:\Windows\system32>jinfo -flag ThreadStackSize 3864
-XX:ThreadStackSize=0

我们会神奇的发现ThreadStackSize 为0,为什么会是0,默认不是为512K~1024K吗?我们翻看oracle的官网文档

jdk8的文档


jdk11的文档


意思就是说如果是window系统默认值取决于虚拟内存。


二:-XX:+PrintGCDetails 参数说明,我们启动一个程序,代码如下

package com.mszl.gc;

public class GcDemo3 {

public static void main(String[] args) {
byte[] bt=new byte[30 * 1024 * 1024]; // 设置为30M
}


}

我们在eclipse里面设置最大堆内存为10M,而我们的程序为30M,会报堆内存异常。

-Xms10m -Xmx10m

执行结果:

[GC (Allocation Failure) [DefNew: 706K->320K(3072K), 0.0013290 secs][Tenured: 153K->473K(6848K), 0.0016831 secs] 706K->473K(9920K), [Metaspace: 1723K->1723K(4480K)], 0.0030903 secs] [Times: user=0.01 sys=0.00, real=0.00 secs] 
[Full GC (Allocation Failure) [Tenured: 473K->462K(6848K), 0.0014379 secs] 473K->462K(9920K), [Metaspace: 1723K->1723K(4480K)], 0.0014710 secs] [Times: user=0.00 sys=0.00, real=0.00 secs]
Exception in thread "main" java.lang.OutOfMemoryError: Java heap space


GC的日志分析图


Full GC的日志分析图


三:-XX:SurvivoRatio参数说明,我们启动一个程序,代码如下

package com.mszl.gc;

public class GcDemo3 {

public static void main(String[] args) {
byte[] bt=new byte[10 * 1024 * 1024];
}


}

我们在eclipse里面设置jvm参数

执行结果

Heap
def new generation total 4928K, used 885K [0x03e00000, 0x04350000, 0x09350000)
eden space 4416K, 20% used [0x03e00000, 0x03edd478, 0x04250000)
from space 512K, 0% used [0x04250000, 0x04250000, 0x042d0000)
to space 512K, 0% used [0x042d0000, 0x042d0000, 0x04350000)
tenured generation total 10944K, used 10240K [0x09350000, 0x09e00000, 0x13e00000)
the space 10944K, 93% used [0x09350000, 0x09d50010, 0x09d50200, 0x09e00000)
Metaspace used 1728K, capacity 2242K, committed 2368K, reserved 4480K

我们可以看到512*8 = 4096 约等于4416,满足 Eden:s0:s1=8:1:1

此时我们在将jvm的参数调下:

-XX:+PrintGCDetails -XX:SurvivorRatio=6

运行程序

Heap
def new generation total 4800K, used 822K [0x03e00000, 0x04350000, 0x09350000)
eden space 4160K, 19% used [0x03e00000, 0x03ecda00, 0x04210000)
from space 640K, 0% used [0x04210000, 0x04210000, 0x042b0000)
to space 640K, 0% used [0x042b0000, 0x042b0000, 0x04350000)
tenured generation total 10944K, used 10240K [0x09350000, 0x09e00000, 0x13e00000)
the space 10944K, 93% used [0x09350000, 0x09d50010, 0x09d50200, 0x09e00000)
Metaspace used 1728K, capacity 2242K, committed 2368K, reserved 4480K

640 * 6 = 3840 约等于4160


四:-XX:NewRatio参数说明,我们启动一个程序,代码如下

package com.mszl.gc;

public class GcDemo3 {

public static void main(String[] args) {
byte[] bt=new byte[10 * 1024 * 1024];
}


}

eclipse jvm参数配置如下

执行结果:

Heap
def new generation total 4928K, used 885K [0x03c00000, 0x04150000, 0x09150000)
eden space 4416K, 20% used [0x03c00000, 0x03cdd478, 0x04050000)
from space 512K, 0% used [0x04050000, 0x04050000, 0x040d0000)
to space 512K, 0% used [0x040d0000, 0x040d0000, 0x04150000)
tenured generation total 10944K, used 10240K [0x09150000, 0x09c00000, 0x13c00000)
the space 10944K, 93% used [0x09150000, 0x09b50010, 0x09b50200, 0x09c00000)
Metaspace used 1728K, capacity 2242K, committed 2368K, reserved 4480K

我们可以发现新生代为 4928 * 2 = 9856 约等于10944,也就是新生代和老年代的比例为1:2


五:-XX:MaxTenuringThreshold参数说明,我们启动一个程序,代码如下

package com.mszl.gc;
/**
* 功能:演示jvm默认MetaspaceSize大小
* 备注:更多资料请访问 http://www.91mszl.com
* @author bobo teacher
*/
public class GcDemo1 {

public static void main(String[] args) {
System.out.println(" hello http://www.91mszl.com");
try {
Thread.sleep(100000000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}


}

cmd 执行命令

C:\Windows\system32>jps -l
5648
6420 com.mszl.gc.GcDemo1
7476 sun.tools.jps.Jps
5548

C:\Windows\system32>
C:\Windows\system32>jinfo -flag MaxTenuringThreshold 6420
-XX:MaxTenuringThreshold=15

我们发现MaxTenuringThreshold默认为15

我们在eclipse 里面配置jvm的参数

-XX:+PrintGCDetails -XX:MaxTenuringThreshold=30

执行程序后报错

MaxTenuringThreshold of 30 is invalid; must be between 0 and 15

说明 MaxTenuringThreshold 只能为0 - 15之间。 

我们现在再eclipse里面将MaxTenuringThreshold改为10

-XX:+PrintGCDetails -XX:MaxTenuringThreshold=10

再次执行程序

C:\Windows\system32>jps -l
5648
2788 sun.tools.jps.Jps
3084 com.mszl.gc.GcDemo1
5548

C:\Windows\system32>jinfo -flag MaxTenuringThreshold 3084
-XX:MaxTenuringThreshold=10

我们发现MaxTenuringThreshold 已经改为了我们期望的值10 


2019-12-05 23:01:19     阅读(1442)

名师出品,必属精品    https://www.91mszl.com

联系博主    
用户登录遮罩层
x

账号登录

91名师指路-底部