我们有一个应用程序生成新的JVM并代表我们的用户执行代码.有时候,内存不足,在这种情况下,行为方式非常不同.有时候他们会抛出一个OutOfMemoryError,有时候它们会冻结.我可以通过非常轻量级的后台线程检测到后者,当内存不足时,它停止发送心跳信号.在这种情况下,我们杀死了JVM,但我们永远不能绝对确定没有收到心跳的真正原因是什么. (它也可能是网络问题或分段错误.)
在JVM中可靠地检测到内存不足的最佳方法是什么?
>理论上,-XX:OnOutOfMemoryError选项看起来很有前途,但由于这个错误,它实际上是不可用的:https://bugs.openjdk.java.net/browse/JDK-8027434
>捕获OutOfMemoryError实际上不是一个很好的选择,因为众所周知的原因(例如,你永远不会知道它在哪里发生),尽管它在许多情况下都有效.
>剩下的情况是那些JVM死机且不会抛出OutOfMemoryError的情况.我仍然确定记忆是这个问题的原因.
是否有任何替代方案或解决方法?垃圾收集设置使JVM终止本身而不是冻结?
编辑:我完全控制了分叉和分叉的JVM,以及正在执行的代码,都在Linux上运行,如果有帮助,可以使用操作系统特定的实用程序.