如何减少JVM虚拟内存的使用?

时间:2012-08-19 09:32:57

标签: java unix jvm solaris

我有一个Java程序可以在具有2GB物理内存和2GB交换的Solaris 10 X86上运行。

该程序在Linux 64位运行良好,只消耗大约450MB内存。

但是当它在Solaris中运行时,它总是报告OutOfMemoryError,我注意到在错误发生之前,它正在尝试使用> 4GB的虚拟内存,这在32位系统上绝对不可能。

那么为什么JVM会尝试使用那么多虚拟内存呢?有没有办法告诉JVM不要使用那么多虚拟内存?

谢谢。

编辑:

感谢大家的意见!以下是完整的错误消息:

#
# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (malloc) failed to allocate 32756 bytes for ChunkPool::allocate
# Possible reasons:
#   The system is out of physical RAM or swap space
#   In 32 bit mode, the process size limit was hit
# Possible solutions:
#   Reduce memory load on the system
#   Increase physical memory or swap space
#   Check if swap backing store is full
#   Use 64 bit Java on a 64 bit OS
#   Decrease Java heap size (-Xmx/-Xms)
#   Decrease number of Java threads
#   Decrease Java thread stack sizes (-Xss)
#   Set larger code cache with -XX:ReservedCodeCacheSize=
# This output file may be truncated or incomplete.
#
#  Out of Memory Error (allocation.cpp:211), pid=1052, tid=16
#
# JRE version: 6.0_26-b03
# Java VM: Java HotSpot(TM) Server VM (20.1-b02 mixed mode solaris-x86 )

---------------  T H R E A D  ---------------

Current thread (0x081a3400):  JavaThread "C2 CompilerThread1" daemon

2 个答案:

答案 0 :(得分:3)

您可能正在将参数传递给JVM,使其使用这么多内存。

取决于确切的错误 - 是堆空间问题还是permgen空间问题? - 将参数传递给jvm,例如-Xms512m和-Xmx512m,或-XX:PermSize = 128m和-XX:MaxPermSize = 128m,可能会解决您系统上的问题。

答案 1 :(得分:2)

尝试设置jvm param -Xmx1g以限制最多1千兆字节的使用。