我有一个在Linux服务器上运行的独立Java问题.我用-Xmx256m启动了jvm.我附加了一个JMX监视器,可以看到堆永远不会真正通过256Mb.但是,在我的linux系统上运行top命令时,我可以看到:
1)首先,此过程的RES内存使用量约为350Mb.为什么?我想这是因为堆外的内存?
2)其次,这个过程的VIRT内存使用量不断增长和增长.它永远不会停止!它现在显示在2500Mb!我有泄漏吗?但堆不会增加,它只是循环!
最终这会带来问题,因为系统的交换不断增长并最终导致系统死亡.
有什么想法发生了什么?
我想问的一个重要问题是,这可能是我的代码而不是JVM,kernal等的一些情况.例如,如果线程数量不断增长,那么这符合我观察的描述吗?你可以建议我注意哪些类似的东西?
最佳答案