一文搞懂!JVM内存参数配置
首先我们知道:JVM发生内存错误的类型
1、堆内存泄漏:OutOfMemory:Javaheapspace
此种内存泄漏,增加内存,只能暂时解决问题,并不能根治问题。必须要优化代码,一定是代码的问题:排查堆中的大量对象,就会发现,这些对象都被引用,对象不能及时被回收,导致超出了堆的设定最大内存。
2、老年代内存泄漏:OutOfMemoryError:PermGenspace
类名、访问修饰符、字段描述、方法描述等,所占空间大于永久代最大值,就会出现,一般都是初始化内存的时候,空间太小,解决办法是扩大空间
3、栈内存泄漏:StackOverflowError
代码执行时,代码进栈,此刻如果栈的内存不足以容纳要进栈的代码的大小空间,那么久会报该错误。可以通过设置栈的空间大小。一般通过:Xss设置线程的大小来解决。比如:Xss256m
下面进入如何检测jvm内存情况的实际操作:
1、监控JVM的GC情况:
jstatgcutilpid200020(只需要看O,如果达到100,并且长期处于100,则代表老年代内存不足)
pid:服务进程的pid,可通过:psefgrepjava来查看java的服务进程pid
2000:每隔多少秒进行监控一次。这里是2秒
20:总共获取20次
E:eden区
O:老年代
P:永久代
YGC:新生代的GC次数
YGCT:当前统计的YGC一共花费的时间(毫秒)
FGC:fullGC老年代的GC次数
FGCT:当前统计的FGC一共花费的时间(毫秒)
GCT:YGCFGC
2、查看jvm配置信息
jmapheadpid可以看到java进程的堆的配置信息,各区的空间大小和配置信息
3、查看jvm中类和对象的占用情况
jmaphisto5279head20查看jvm中各个类的实例数、占用内存数量以及类的全名
4、上面使我们的基本命令使用,那么我们怎么预测或者说内存泄漏会有什么征兆?
1、tps出现大幅波动,并慢慢降低,甚至降为0,响应时间随之波动,慢慢升高
2、通过jstat命令看到,Jvm中Old区不断增加,FullGC非常频繁,对应的FullGC消耗的时间也不断增加
3、通过jconsolejvisualvm可以看到,堆内存曲线不断上升,接近上限时,变成一条直线
4、日志报错java。lang。OutOfMemoryError:Javaheapspace
5、内存泄露怎么定位?
(1、确定征兆:现象方面,Java进程抛出OOM异常,分析属于那种异常,是正常的内存资源耗尽还是内存泄漏。
(2、监控jvm的GC情况:jstatgcutilpid1000100(只需要看O,如果达到100,并且长期处于100,则代表老年代内存不足)如果有大量的FGC就要查询是否有内存泄漏的问题了
(3、通过jmap命令:jmaphistopidhead20,查看当前堆内存中实例数和占用内存最多的前20个对象
(4、通过jvisualvm分析定位:进行远程堆dump,然后把dump文件下载下来,用jvisualvm打开进行分析,可以看到更直观的jvm中对象的信息
6、下面是进行最后的JVM参数调优:
vm常用参数
堆内存年轻代老年代
年轻代EdenSurvivor
SurvivorFromSpaceToSpace
年轻代EdenFromSpaceToSpace
堆内存EdenFromSpaceToSpace老年代
Xms2048m:初始堆大小,建议物理内存的14,默认值为物理内存的164
Xmx2048m:最大堆大小,建议与Xms保持一致,默认值为物理内存的14
Xmn512m:新生代大小,建议不超过堆内存的12Xss256k,线程堆栈大小,建议256k
XX:PermSize256m:永久代初始值,默认值为物理内存的164
XX:MaxPermSize256m:永久代最大值,默认值为物理内存的14
XX:SurvivorRatio8:年轻带中Eden区和Survivor区的比例,默认为8:1,即Eden(8),FromSpace(1),ToSpace(1)
XX:MaxTenuringThreshold15:晋升到老年代的对象年龄,每个对象坚持过一次MinorGC后对象年龄1,默认值是15,年龄超过15进入到老年代,该参数在串行GC时有效
XX:PretenureSizeThreshold3145728:单位字节,只对Serial和ParNew两款收集器有效,新生代采用ParallelScavengeGC时无效,大于这个值的对象直接在老年代进行分配
7、参数设置在哪里?
一般来说,一个服务器可能有多个java服务进行,对吧?是很多服务器都会有这种情况,那么问题来了,那我要是统一在jvm配置文件修改jvm参数,那么岂不是所有服务都是这个参数?所以有没有其他办法?
有!!!!那就是在java进程启动命令设置。
nohupjava{JAVAOPT}jarxxx。jar21
JAVAOPT的参数:里面参数自行看要设置什么,以及具体的参数值
JAVAOPTserverXms256mXmx256mXmn512mXX:MetaspaceSize64mXX:MaxMatespaceSize256m