最近排查一个线上java服务常驻内存异常高的问题,大概现象是:java堆Xmx配置了8G,但运行一段时间后常驻内存RES从5G逐渐增长到13G #补图#,导致机器开始swap从而服务整体变慢.由于Xmx只配置了8G但RES常驻内存达到了13G,多出了5G堆外内存,经验上判断这里超出太多不太正常. 前情提要–JVM内存模型 开始逐步对堆外内存进行排查,首先了解一下JVM内存模型.根据JVM规范,JVM运行时数据区共分为虚拟机栈.堆.方法区.程序计数器.本地方法栈五个部分. 虚拟机栈:每个线程有一…