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

标签 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

最佳答案

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

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

关于java - 如何减少JVM虚拟内存的使用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12025525/

相关文章:

java - 需要帮助制作按钮继电器信息

c - 在多对象/结构 X11 显示的情况下如何从窗口中删除对象?

c++ - 根据 S_ISREG C/C++, "regular file"是什么意思?

java - 将 JVM 绑定(bind)到默认 IP 之外的 IP

java - 看来 retransformClasses 删除了用户定义的属性(?)如何向通过重新转换保留的方法添加注释?

crash - 如何在JVM中读取 'Top of Stack'生成的hs_err_pidxxx.log

Java Hibernate 对象在一段时间后失去其值(value)

java - Tomcat 在哪里附加/到目录路径?

java - 用Java用Socket链接两台计算机

java - 使用 Java 分析系统内存/CPU 统计信息