无法为对象堆保留足够的空间


277

每次尝试运行该程序时,我都会反复收到以下异常。

VM初始化期间发生错误

无法为对象堆保留足够的空间

无法创建Java虚拟机。

我试图增加虚拟内存(页面大小)和RAM大小,但无济于事。

如何消除此错误?



2
在我的虚拟机上使用jdk / jre 1.6时,在尝试更改注释中给出的配置值时,我也遇到此错误,但这无济于事,将其更新为jdk 1.7后,错误消失了,并应用了较大的Xmx参数。自Java 1.6以来,堆使用似乎发生了许多变化。
Alexander.Iljushkin

Answers:


214

使用JVM -XX:MaxHeapSize=512m(或任意数量)(或-Xmx512m简称)运行JVM


42
或更短的-mx256m或-mx512m;)
Peter Lawrey 2010年

8
-mx与-Xmx和-XX:MaxHeapSize相同吗?
Erty Seidohl

19
谢谢..事实证明,数字太大也可能是一个问题,并且可能导致相同的错误!
Dinesh Rajan 2014年

17
有人找到了实际上可以100%起作用的解决方案吗?此解决方案暂时解决了问题,但是突然又回来了。我有16GB的ram,我已经厌倦了这个问题。在过去,一切都变好了:[
Nilzor 2014年

6
在使用x86或x64 Java的Windows 8上对我不起作用。
AndrewSmiley 2015年

128

这也可能是由于在32位HotSpot虚拟机上设置的值过大而引起的,例如:

-Xms1536m -Xmx1536m

可能/将在哪里工作:

-Xms1336m -Xmx1336m

5
我忘了提到在32位命令Shell中启动时必须发生此问题。64位命令外壳程序可能不会出现此问题。
djangofan 2012年

对我来说,它使用默认值和太大的值失败,因此请确保尝试多个值。感谢你的回答!
Trax

47

解决方法如下:

  • 转到开始->控制面板->系统->高级(选项卡)->环境变量->系统

    变量->新增:变量名称:_JAVA_OPTIONS 变量值:-Xmx512M 变量名称:Path
    变量值:%PATH%;C:\Program Files\Java\jre6\bin;F:\JDK\bin;

将此更改为您合适的路径。


1
我会说很类似于这个答案 ……
That1Guy 16'May

好一个 除上述内容外,也请参考此内容。stackoverflow.com/a/9350506/967638
Amarnath

46

我在使用javac时遇到了这个问题,并且在命令行选项中似乎没有发现,

-bash-3.2$ javac -Xmx256M HelloWorldApp.java 
Error occurred during initialization of VM
Could not reserve enough space for object heap
Error: Could not create the Java Virtual Machine.
Error: A fatal exception has occurred. Program will exit.

所以这里的解决方案就这样设置_JAVA_OPTIONS

-bash-3.2$ export _JAVA_OPTIONS="-Xmx256M"
-bash-3.2$ javac HelloWorldApp.java 
Picked up _JAVA_OPTIONS: -Xmx256M

这样编译就可以了。

这在具有大量RAM但内存限制较低的计算机上发生。Java之所以决定分配一个大堆,是因为它在机器中检测到了ram,但是由于ulimits的原因,它不允许分配它。


1
+1指出_JAVA_OPTIONS -在我的情况下,java是从我没有写访问权的shell脚本中的某个深处调用的,因此此选项是可取的。
格里特

同样在这里。我使用的是大学计算机,所以我不是管理员(无法更改环境变量),并且命令行选项根本不起作用。非常感谢!
Kimbluey '17

38

32位Java需要内存中连续的可用空间才能运行。如果您指定较大的堆大小,则即使您的可用空间比必要的多得多,内存中也可能没有太多的连续可用空间。

在这些情况下,安装64位版本的Java会有所帮助,连续内存要求仅适用于32位Java。


1
我认为这是最好的答案,以防您在使用-Xmx [bignumber] m选项后仍然收到错误消息。帮助我正确运行了Apache jMeter。
RuudvK '18

我创建了一个全新的项目,除了自动生成的主要活动外,没有其他任何代码,并且产生了此错误
相信

1
我第二个@RuudvK。安装64位可以让我增加最大内存,同时清除内存分配错误。这应该是公认的答案。
J Weezy

28

与-Xmx512M结合使用,请使用-d64以确保您正在运行64位VM。我确定在64位计算机上运行的是64位虚拟机,但没有。安装64位Java后,-d64选项有效,-Xmx允许更大的内存大小。

java -d64 -Xmx512M mypackage.Test

4
这个答案应该在顶部。花了两个月的时间来解决这个问题,只是意识到安装64位Java可以解决该问题(在我的情况下,无需使用-d64选项)
Nilzor 2014年

拾取了_JAVA_OPTIONS:-d64 -Xmx1024M无法识别的选项:-d64无法启动JVM。最大堆大小(-Xmx)可能太大,或者防病毒或防火墙工具可能阻止执行。
亚历山大

14

我遇到了相同的错误,并通过在run.conf.bat中对其进行配置解决了该问题

在Jboss5x中使用配置run.conf.bat运行JVM

如果没有可用内存,请在run.conf.bat中进行更改。

set "JAVA_OPTS=-Xms512m -Xmx512m -XX:MaxPermSize=256m"

7

我知道这里已经有很多答案,但是没有一个对我有帮助。最后,我打开了文件/etc/elasticsearch/jvm.options并进行了更改:

-Xms2G
-Xmx2G

-Xms256M
-Xmx256M

那为我解决了。希望这对这里的其他人有帮助。


7

我有类似的问题。我已经在64位计算机上安装了32位Java版本。

通过卸载该版本并安装Java的64位版本。我能够解决问题。


6

假设您的课程是Test在package中调用的mypackage。像这样运行代码:

java -Xmx1024m mypackage.Test

这将为您的代码保留1024 MB的堆空间。如果需要512 MB,则可以使用:

java -Xmx512m mypackage.Test

使用小米1024m512m


6

有时,此错误表明服务器上的物理内存和交换实际上已被充分利用!

我最近在运行具有48 GB RAM的RedHat Enterprise Linux 5.7的服务器上看到此问题。我发现即使只是跑步

java -version

导致了同样的错误,这表明问题并非特定于我的应用程序。

跑步

cat /proc/meminfo

报告说,MemFree和SwapFree分别远低于MemTotal和SwapTotal值的1%:

MemTotal:     49300620 kB
MemFree:        146376 kB
...
SwapTotal:     4192956 kB
SwapFree:         1364 kB

停止计算机上其他一些正在运行的应用程序会使可用内存有所增加:

MemTotal:     49300620 kB
MemFree:       2908664 kB
...
SwapTotal:     4192956 kB
SwapFree:      1016052 kB

此时,可以启动一个新的Java实例,并且我能够运行我的应用程序。

(显然,对我来说,这只是一个临时解决方案;我仍然有一项出色的任务,需要更彻底地检查该计算机上运行的进程,以查看是否可以采取一些措施来降低名义内存利用率水平,而无需不得不停止应用程序。)


同样,这里java -version失败了,即使top仍然显示了一些空闲:| (也说VM初始化期间发生错误,有时无法为卡标记阵列保留足够的空间)。修复似乎是在运行,寻找哪些进程使用了​​最多的RAM(VIRT列),杀死它们[postgres,对我来说是应用程序动力学]:|
rogerdpack '16

这可能是由于内存碎片造成的吗?上面的答复提到了连续的可用空间。
瑞克·莫里兹

6

错误:

对于错误, “ vm初始化期间发生无法为对象堆jboss保留足够的空间”

根本原因 :

  • 如下所述,对我们的JVM的内存分配不正确/不足。

  • 例如: - JAVA_OPTS = “MaxPermSize参数=256米Xms1303m -Xmx1303m -XX”在JBoss中-EAP-6.2 \ BIN \ standalone.conf或: “MaxPermSize参数= 256M JAVA_OPTS = -Xms1G -Xmx1G -XX”在JBoss中-EAP-6.2 \ bin中\ standalone.conf.bat就是JVM内存分配池参数。

解析度 :

  • 增加堆大小。为了增加堆大小,
  • 转到-> jboss-eap-6.2 \ bin \ standalone.conf.bat或jboss-eap-6.2 \ bin \ standalone.conf
  • 更改-> JAVA_OPTS =“-Xms256m -Xmx512m -XX:MaxPermSize = 256m”,其中-Xms是最小堆大小,-Xmx是最大堆大小。
  • 通常不建议最小和最大大小相同。

  • 如果您是从eclipse运行应用程序,

  • 双击服务器
  • 选择“打开启动配置”,您将被重定向到“编辑启动配置属性”窗口。
  • 在此窗口中,转到选项卡'(x)= Arguments'。
  • 在VM参数中,如下所述定义堆大小
  • “ -Dprogram.name = JBossTools:JBoss EAP 6.1+运行时服务器” -server -Xms256m -Xmx512m -XX:MaxPermSize = 256m -Dorg.jboss.resolver.warning = true

Oracle命令行参考中的引号:“ 为获得最佳性能,请将-Xms设置为与最大堆大小相同的大小,例如:java -Xgcprio:throughput -Xmx:64m -Xms:64m myApp
user1438038,3年

3

我最近遇到了这个问题。我有3个以1024m或1280m堆大小开头的Java应用程序。Java正在查看交换中的可用空间,如果没有足够的可用内存,则jvm将退出。

要解决此问题,我必须结束几个分配了大量虚拟内存的程序。

我在具有64位jvm的x86-64 linux上运行。


3

我的内存设置数量合适,但对我来说,它使用的是64位intellij和32位jvm。切换到64位VM后,错误消失了。



2

如果您正在运行32位JVM,则将堆大小更改为较小可能会有所帮助。您可以通过直接将args传递给java或通过以下环境变量来实现此目的,

java -Xms128M -Xmx512M
JAVA_OPTS="-Xms128M -Xmx512M"

对于64位JVM,-Xms512M -Xmx1536M应使用更大的堆大小。

对Java7 运行java -versionjava -d32java--d64以检查您正在运行的版本。


1

无论如何,这是解决方法:转到“开始”->“控制面板”->“系统”->“高级(选项卡)”->“环境变量”->“系统变量”->“新建”:变量名称:_JAVA_OPTIONS变量值:-Xmx512M

要么

如下更改蚂蚁的呼叫。

   <exec
        **<arg value="-J-Xmx512m" />**
    </exec>

它为我工作。



1

转到“开始”->“控制面板”->“系统”->“高级(选项卡)”->“环境变量”->“系统变量”->“新建”:

Variable name: _JAVA_OPTIONS
Variable value: -Xmx512M

全局设置此项会限制您可以赋予IntelliJ的堆大小。
user3056052

0

如果您正在运行Java程序:-在终端上使用适用于Linux的正确命令运行您的程序,它将是'java -jar myprogram.jar'并添加-Xms256m -Xmx512m,例如:'java -jar myprogram.jar Xms256m -Xmx512m'

如果您正在运行.sh脚本(Linux,mac?)或.bat脚本(Windows),请打开该脚本并查找Java选项(如果存在)并增加内存。

如果上述所有方法均无效,请检查您的进程(在Windows上为ctrl + alt + delete)(在linux / mac上为ps aux),并杀死使用内存分配的进程,这些进程对于您的操作系统不是必需的!=>尝试重新运行您的程序。


0

在CASSANDRA_HOME / bin / cassandra.bat中,您将找到以下配置

REM JVM Opts we'll use in legacy run or installation
set JAVA_OPTS=-ea^
 -javaagent:"%CASSANDRA_HOME%\lib\jamm-0.3.0.jar"^
 -Xms**2G**^
 -Xmx**2G**^

您可以将2G减少到较小的数量,例如1G或更小,它应该可以工作。

如果在Unix框上运行,则相同,请在.sh文件中进行适当更改。


0

当我使用%temp%删除临时文件并重新启动Eclipse时,我遇到了同样的错误,并且已解决。


0

有时它与

$ sysctl vm.overcommit_memory
vm.overcommit_memory = 2

如果将其设置为:

$ sysctl vm.overcommit_memory=0

它应该工作。


0

在cassandra bin目录中的cassandra.bat文件中替换-Xmx2G-Xms512M或更大的内存大小。


0

在android文件夹中打开gradle.properties文件。

替换此行:

org.gradle.jvmargs=-Xmx1536M

与:

org.gradle.jvmargs=-Xmx512m

说明:Gradle文档中的最大限制:

如果请求的构建环境未指定最大堆大小,则守护程序将使用最多512MB的堆。


-2

只需更改POM文件中的内容,无需进行任何操作,如下所示

<configuration>
    <maxmemory>1024M</maxmemory>
</configuration>

2
谁对POM文件说了什么?
Henley Chiu
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.