ubuntu上的Java内存不足,但存在大量缓存内存

时间:2015-12-04 08:39:57

标签: java linux ubuntu caching memory-management

我有一个带4GB RAM的ubuntu 14.04系统,x86_64 3.13.0-48通用内核和openjdk-7。

我的记忆用法如下:

# free -h
             total       used       free     shared    buffers     cached
Mem:          3.7G       3.6G       127M       988M        44M       3.3G
-/+ buffers/cache:       232M       3.4G
Swap:           0B         0B         0B

因此,有足够的内存用作磁盘缓存,当任何应用程序需要时,应该刷新并释放(AFAIK)。

所以,我尝试运行java:

# java -Xms32m -Xmx512m -version
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 -version会返回相同的结果。当有3GB的缓存内存时,为什么java不能运行?我在同一台机器上运行PostreSQL,但它的shared_buffers设置为940MB。

编辑:

我强制刷新磁盘缓存 - 结果仍然相同:

# free -h
             total       used       free     shared    buffers     cached
Mem:          3.7G       1.9G       1.8G       988M        35M       1.7G
-/+ buffers/cache:       196M       3.5G
Swap:           0B         0B         0B
# java -Xms32m -Xmx512m -version
Error occurred during initialization of VM
Could not reserve enough space for object heap
Could not create the Java virtual machine.

EDIT2:

以下是ulimit -a

# ulimit -a
core file size          (blocks, -c) 0
data seg size           (kbytes, -d) unlimited
scheduling priority             (-e) 0
file size               (blocks, -f) unlimited
pending signals                 (-i) 30034
max locked memory       (kbytes, -l) 64
max memory size         (kbytes, -m) unlimited
open files                      (-n) 1024
pipe size            (512 bytes, -p) 8
POSIX message queues     (bytes, -q) 819200
real-time priority              (-r) 0
stack size              (kbytes, -s) 32000
cpu time               (seconds, -t) unlimited
max user processes              (-u) 30034
virtual memory          (kbytes, -v) unlimited
file locks                      (-x) unlimited

EDIT3:

我完全没有得到它:我尝试添加4GB交换,结果是它可以工作,虽然没有使用交换:

# free -h
             total       used       free     shared    buffers     cached
Mem:          3.7G       3.5G       196M       988M        44M       3.2G
-/+ buffers/cache:       239M       3.4G
Swap:         4.0G         0B       4.0G
# java -version
java version "1.6.0_36"
OpenJDK Runtime Environment (IcedTea6 1.13.8) (6b36-1.13.8-0ubuntu1~14.04)
OpenJDK 64-Bit Server VM (build 23.25-b01, mixed mode)

2 个答案:

答案 0 :(得分:2)

你需要运行一些东西。

java -Xmx1024m -cp /path/to/jar/ com.project.Start

答案 1 :(得分:1)

Java提供了正确的答案:对于此堆大小,您在该计算机上没有足够的可用内存。

您是否在此计算机上尝试了top后跟Shift + M?你的机器上有很多缓冲的东西,这是真的。

您没有添加交换分区的原因?

另外,您可以在此处查看:http://javahowto.blogspot.de/2006/06/6-common-errors-in-setting-java-heap.html