如何解决JVM OutOfMemoryError内存泄漏问题?


没有任何神奇的工具可以为您修复OutOfMemoryError,但是下面有一些选项可以帮助您自动排除故障并确定根本原因。按照以下三个步骤来处理此JVM内存错误并开始恢复:

  1. 捕获JVM堆转储
  2. 重启应用程序
  3. 诊断问题

1.捕获堆转储
堆转储是在指定时间点J内ava程序内存中的内容的快照。它包含有关存储器中存在的对象的详细信息,这些对象中存在的实际数据,这些对象如何维护到其他对象以及其他信息。堆转储是修复OutOfMemoryError的重要步骤,但它们确实存在一些挑战,因为它们的内容可能难以阅读和解密。
在最佳情况下,您希望在OutOfMemoryError之前或之前捕获堆转储以诊断原因,但这并不容易。但是,您可以自动执行此堆转储过程。通过使用以下变量编辑JRE的启动参数,告诉JVM创建堆转储:

-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/crashes/my-heap-dump.hprof


2.重新启动麻烦的应用程序
大多数情况下,OutOfMemoryError不会使应用程序崩溃,但它可能会使应用程序处于不稳定状态。在这种情况下重启将是一种谨慎的举动,因为不稳定的应用程序实例提供的请求会导致错误的结果。

您也可以自动执行此重启过程。只需编写一个“restart-myapp.sh”脚本,它会重启您的应用程序。向JVM提供命令行参数,以便在遇到异常时触发它以运行以下脚本:

-XX:OnOutOfMemoryError=/scripts/restart-myapp.sh

传递此参数时,只要抛出OutOfMemoryError,JVM就会调用“/scripts/restart-myapp.sh”脚本。因此,您的应用程序将在遇到OutOfMemoryError后立即自动重新启动。


3.诊断问题
现在您已经捕获了堆转储 - 这是解决问题所需 - 并重新启动应用程序 - 以减少中断影响 - 下一步是故障排除。

如上所述,理解堆转储的内容可能很棘手,但有一些有用的堆分析器工具可以帮助简化流程。一些选项包括Eclipse Memory Analyzer(MAT),Oracle JHat或HeapHero

这些工具生成内存分析报告,突出显示导致最大内存的对象,并希望帮助识别导致内存泄漏的对象。
当您的应用程序遇到运行时错误时,这会非常令人沮丧。您需要耐心,内存堆转储以及分析问题的适当工具来修复OutOfMemoryError以及类似类似的其他令人讨厌的异常。