测试驿栈-由浅入深学性能 性能测试连载 (22)-jvm 内存参数设置

飞天小子的性能课堂 · 2019年11月13日 · 1504 次阅读

性能答疑 QQ 群:697244251

概述

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 字节的直接在老年代分配对象

如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
暂无回复。
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册