如何解决“java.io.IOException: error=12, Can allocate memory”调用 Runtime#exec()的问题?

2022-08-31 14:34:16

在我的系统上,我无法运行启动进程的简单Java应用程序。我不知道如何解决。

你能给我一些提示如何解决吗?

该计划是:

[root@newton sisma-acquirer]# cat prova.java
import java.io.IOException;

public class prova {

   public static void main(String[] args) throws IOException {
        Runtime.getRuntime().exec("ls");
    }

}

结果是:

[root@newton sisma-acquirer]# javac prova.java && java -cp . prova
Exception in thread "main" java.io.IOException: Cannot run program "ls": java.io.IOException: error=12, Cannot allocate memory
        at java.lang.ProcessBuilder.start(ProcessBuilder.java:474)
        at java.lang.Runtime.exec(Runtime.java:610)
        at java.lang.Runtime.exec(Runtime.java:448)
        at java.lang.Runtime.exec(Runtime.java:345)
        at prova.main(prova.java:6)
Caused by: java.io.IOException: java.io.IOException: error=12, Cannot allocate memory
        at java.lang.UNIXProcess.<init>(UNIXProcess.java:164)
        at java.lang.ProcessImpl.start(ProcessImpl.java:81)
        at java.lang.ProcessBuilder.start(ProcessBuilder.java:467)
        ... 4 more

系统配置:

[root@newton sisma-acquirer]# java -version
java version "1.6.0_0"
OpenJDK Runtime Environment (IcedTea6 1.5) (fedora-18.b16.fc10-i386)
OpenJDK Client VM (build 14.0-b15, mixed mode)
[root@newton sisma-acquirer]# cat /etc/fedora-release
Fedora release 10 (Cambridge)

编辑:解决方案这解决了我的问题,我不知道为什么:

echo 0 > /proc/sys/vm/overcommit_memory

赞成谁能够解释:)

其他信息,顶部输出:

top - 13:35:38 up 40 min,  2 users,  load average: 0.43, 0.19, 0.12
Tasks: 129 total,   1 running, 128 sleeping,   0 stopped,   0 zombie
Cpu(s):  1.5%us,  0.5%sy,  0.0%ni, 94.8%id,  3.2%wa,  0.0%hi,  0.0%si,  0.0%st
Mem:   1033456k total,   587672k used,   445784k free,    51672k buffers
Swap:  2031608k total,        0k used,  2031608k free,   188108k cached

附加信息,免费输出:

[root@newton sisma-acquirer]# free
             total       used       free     shared    buffers     cached
Mem:       1033456     588548     444908          0      51704     188292
-/+ buffers/cache:     348552     684904
Swap:      2031608          0    2031608

答案 1

这是解决方案,但您必须设置:

echo 1 > /proc/sys/vm/overcommit_memory

答案 2

您机器的内存配置文件是什么?例如,如果您运行,您有多少可用内存?top

我怀疑执行了一个,它只是没有从操作系统获得足够的内存(如果内存服务,它将复制进程,然后在新的内存进程中运行ls,并且它没有达到那么远)UnixProcessfork()fork()exec()

编辑:重新提交您的过度使用解决方案,它允许系统内存的过度使用,可能允许进程分配(但不使用)比实际可用的内存更多。所以我猜想,正如下面的评论中所讨论的那样,它们复制了Java进程内存。当然,您不会使用内存,因为“ls”会替换重复的Java进程。fork()


推荐