在Java中处理内存不足的最佳方法是什么?

前端之家收集整理的这篇文章主要介绍了在Java中处理内存不足的最佳方法是什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我们有一个应用程序生成新的JVM并代表我们的用户执行代码.有时候,内存不足,在这种情况下,行为方式非常不同.有时候他们会抛出一个OutOfMemoryError,有时候它们会冻结.我可以通过非常轻量级的后台线程检测到后者,当内存不足时,它停止发送心跳信号.在这种情况下,我们杀死了JVM,但我们永远不能绝对确定没有收到心跳的真正原因是什么. (它也可能是网络问题或分段错误.)

在JVM中可靠地检测到内存不足的最佳方法是什么?

>理论上,-XX:OnOutOfMemoryError选项看起来很有前途,但由于这个错误,它实际上是不可用的:https://bugs.openjdk.java.net/browse/JDK-8027434
>捕获OutOfMemoryError实际上不是一个很好的选择,因为众所周知的原因(例如,你永远不会知道它在哪里发生),尽管它在许多情况下都有效.
>剩下的情况是那些JVM死机且不会抛出OutOfMemoryError的情况.我仍然确定记忆是这个问题的原因.

是否有任何替代方案或解决方法垃圾收集设置使JVM终止本身而不是冻结?

编辑:我完全控制了分叉和分叉的JVM,以及正在执行的代码,都在Linux上运行,如果有帮助,可以使用操作系统特定的实用程序.

解决方法

唯一真正的选择是(不幸的是)尽快终止虚拟机.

由于您可能无法更改所有代码以捕获错误并进行响应.如果你不信任OnOutOfMemoryError(我不知道为什么它不应该使用Java 8使用的vfork,并且它在Windows上运行),你至少可以触发一个heapdump并从外面监视这些文件

java .... -XX:+HeapDumpOnOutOfMemoryError "-XX:OnOutOfMemeoryError=kill %p"

猜你在找的Java相关文章