java: java.lang.OutOfMemoryError: Java heap space

报错信息

java: java.lang.OutOfMemoryError: Java heap space

问题描述

idea build代码阶段,报内存溢出错误。

排查原因

这个错误是因为Java虚拟机(JVM)在堆内存空间(Heap Space)中没有足够的空间来分配对象。这可能是因为你的应用程序创建了太多的对象,或者你的堆内存空间设置得太小。

方法一:增加JVM的堆内存空间

你可以通过-Xmx选项来设置JVM的最大堆内存空间。例如,你可以使用以下命令来启动你的应用程序,其中1024m表示最大堆内存空间为1024MB:

java -Xmx1024m -jar your_application.jar

如果你是在IDE(如IntelliJ IDEA或Eclipse)中运行你的应用程序,你可以在你的运行配置中设置JVM选项。配置路径参考:Help->Edit custom VM options 打开文件内容如下:

-XX:ReservedCodeCacheSize=512m:设置代码缓存的大小,代码缓存用于存放JVM编译后的代码。-Xmx2048m:设置JVM堆内存的最大值为2048M,也就是2G。-Xms2048m:设置JVM堆内存的初始值也为2048M,也就是2G。-XX:+UseG1GC:使用G1垃圾收集器。-XX:SoftRefLRUPolicyMSPerMB=50:设置软引用的清理策略,每MB空闲堆内存保留50毫秒的软引用。-XX:CICompilerCount=2:设置并行编译线程的数量。-XX:+HeapDumpOnOutOfMemoryError:在出现内存溢出错误时,导出堆到文件。-XX:-OmitStackTraceInFastThrow:在快速抛出异常时,不省略堆栈跟踪。-ea:启用断言。-Dsun.io.useCanonCaches=false:禁用规范化路径名的缓存。-Djdk.http.auth.tunneling.disabledSchemes="":启用所有的HTTP认证隧道方案。-Djdk.attach.allowAttachSelf=true:允许自附加。-Djdk.module.illegalAccess.silent=true:在模块访问违规时,不显示警告或错误。-Dkotlinx.coroutines.debug=off:关闭Kotlin协程的调试。-XX:ErrorFile=$USER_HOME/java_error_in_idea_%p.log:设置错误日志文件的路径。-XX:HeapDumpPath=$USER_HOME/java_error_in_idea.hprof:设置堆转储文件的路径。

-Xmx参数用于设置Java虚拟机(JVM)堆内存的最大值。其最大值取决于你的系统的硬件和操作系统。
对于32位系统,JVM的最大内存通常限制在1.5G到2G之间。这是因为32位系统的最大寻址空间是4G,其中一部分需要被操作系统和其他应用程序使用。
对于64位系统,理论上,JVM的最大内存可以达到你的物理内存大小。然而,实际上,你需要考虑到操作系统和其他应用程序的内存需求,以及JVM自身的一些限制。一般来说,对于具有大量内存的服务器,你可以将-Xmx设置为数十GB,甚至更大。
但是,你应该根据你的应用程序的实际内存需求来设置-Xmx参数。设置过大的-Xmx值可能会导致内存的浪费,而设置过小的-Xmx值可能会导致OutOfMemoryError。

其次,build报oom异常可以考虑增加虚拟机栈的空间,idea配置路径为:idea->setting>Build,Execution,Deployment->Compiler,修改Shared build process heap size(Mbytes) ,增大虚拟机栈的空间。

方法二:优化你的应用程序

如果你的应用程序创建了太多的对象,或者保留了太多不再需要的对象,那么可能会导致内存泄漏,从而导致OutOfMemoryError。你可以使用一些工具(如VisualVM或MAT)来分析你的应用程序的内存使用情况,找出并修复内存泄漏。