性能测试连载 (22)-jvm 内存参数设置
https://pan.baidu.com/s/1df1HDkFzChYNAbsSazizpw 提取码:hhn7
jmeter 全系列文档资料
https://pan.baidu.com/s/1rD3H9EGbu0u11E8ofpAl3A 提取码:8q65
性能测试初级到高级系列资料
概述
java 内存溢出之后,我们需要根据错误信息分析一下内存溢出的具体原因,及时调整中间件的参数、
查看 jvm 内存分配
linux 下可以通过 jmap -heap【pid】命令查看 jvm 的内存分配
例如:jmap -heap 1
这个图可以看出
MaxHeapSize = 1073741824 (1024.0MB) 最大堆内存 1G
MaxNewSize = 536870912 (512.0MB) 最大新生代内存 512m
OldSize = 536870912 (512.0MB) 老年代内存 512m
NewRatio = 2 表示新生代:老年代=1:2
SurvivorRatio = 8 表示 eden:Survivor=8:1
参数调整
jvm 的参数调整在 catalina.sh 文件中
JAVA_OPTS="-Djava.awt.headless=true -Dfile.encoding=UTF-8 -server -Xms1024m -Xmx1024m -XX:NewSize=512m -XX:NewRatio=2 -XX:SurvivorRatio=8"
设置堆内存:-Xms1024m -Xmx1024m
设置新生代内存:-XX:NewSize=256m -XX:MaxNewSize=256m
设置新生代和老年代的比例:-XX:NewRatio=2
设置伊甸园和 Survivor 的比例:-XX:SurvivorRatio=8
设置栈内存:-Xss1m
每个线程都会产生一个栈。在相同物理内存下,减小这个值能生成更多的线程。如果这个值太小会影响方法调用的深度
设置最大持久代大内存:-XX:MaxPermSize=256m(jdk1.8 之后取消了持久代,改成了元空间)
设置新生代代对象进入老年代的年龄:-XX:MaxTenuringThreshold=16
设置新生代 gc 最大年龄。如果设置为 0 的话,则新生代对象直接进入老年代
设置对象直接进入老年代的内存阈值:-XX:PretenureSizeThreshold=1024
对象大小大于 1024 字节的直接在老年代分配对象