概述
java内存溢出之后,我们需要根据错误信息分析一下内存溢出的具体原因,及时调整中间件的参数、
查看jvm内存分配
linux下可以通过jmap -heap 【pid】命令查看jvm的内存分配
例如:jmap -heap 1
此图可以看出MaxHeapSize = 1073741824 (1024.0MB) 最大堆内存1GMaxNewSize = 536870912 (512.0MB) 最大新生代内存512mOldSize = 536870912 (512.0MB) 老年代内存512mNewRatio = 2 表示新生代:老年代=1:2SurvivorRatio = 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字节的直接在老年代分配对象
个人QQ:1144890271
QQ群:317765580
个人微信:uhz2008