从应用程序内请求Java堆转储(核心转储)

我需要一种方法来从应用程序中请求堆转储。

基本原理:当我遇到特定的错误情况时,我想转储堆,这样我就能看到内存中的内容。

但是我想自动执行此操作(例如,当我检测到某些特定情况已经发生时。或者当看门狗不再获得它的ping时。当某些测试失败时)。 因此,我需要一种从应用程序本身转储堆的方法。 我似乎无法用MX bean找到它。 虽然MX Beans可以提供非常好的堆栈跟踪以及监视器和“可拥有的同步器”信息,死锁和争用信息,但我似乎找不到请求堆转储的方法。 有没有这样的方式? 或者通过一些间接方式,例如,这些JVisualVM事情是如何做到的? 人们可以告诉JVM在OutOfMemoryExceptions上转储核心..?

如果在OutOfMemoryError上转储堆是不够的,那么有一种以HotSpot为依据的方式以编程方式从Java应用程序转储堆 ,如果可以的话。

如何使用VM选项-XX:+HeapDumpOnOutOfMemoryError告诉HotSpot VM在内存不足时生成堆转储?