Java内存之谜(我有泄漏)?

前端之家收集整理的这篇文章主要介绍了Java内存之谜(我有泄漏)?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我有一个在Linux服务器上运行的独立Java问题.我用-Xmx256m启动了jvm.我附加了一个JMX监视器,可以看到堆永远不会真正通过256Mb.但是,在我的linux系统上运行top命令时,我可以看到:

1)首先,此过程的RES内存使用量约为350Mb.为什么?我想这是因为堆外的内存?

2)其次,这个过程的VIRT内存使用量不断增长和增长.它永远不会停止!它现在显示在2500Mb!我有泄漏吗?但堆不会增加,它只是循环!

最终这会带来问题,因为系统的交换不断增长并最终导致系统死亡.

有什么想法发生了什么?

我想问的一个重要问题是,这可能是我的代码而不是JVM,kernal等的一些情况.例如,如果线程数量不断增长,那么这符合我观察的描述吗?你可以建议我注意哪些类似的东西?

最佳答案
一些潜在的问题:

>直接分配的缓冲区和内存映射文件在Java堆外部分配,不能方便地处理.
>为每个新线程保留堆栈区域.
>永久生成(代码和实习字符串)超出了通常的堆栈.它可能是一个问题,类加载器泄漏(通常在重新加载webapps时).
> C堆可能正在泄漏.

pmap -x应该显示你的记忆是如何消失的.

猜你在找的Linux相关文章