`
bittercoffee
  • 浏览: 14482 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

关于JVM PermGen space 深入解析

阅读更多
PermGen space的全称是Permanent Generation space,是指内存的永久保存区域OutOfMemoryError: PermGen space从表面上看就是内存益出,解决方法也一定是加大内存。说说为什么会内存益出:这一部分用于存放Class和Meta的信息,Class在被 Load的时候被放入PermGen space区域,它和和存放Instance的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的APP会LOAD很多CLASS的话,就很可能出现PermGen space错误。这种错误常见在web服务器对JSP进行pre compile的时候。 如果你的WEB APP下都用了大量的第三方jar, 其大小 超过了jvm默认的大小(4M)那么就会产生此错误信息了。
解决方法: 手动设置MaxPermSize大小
改正方法:-Xms256m -Xmx256m -XX:MaxNewSize=256m -XX:MaxPermSize=256m



修改TOMCAT_HOME/bin/catalina.sh
JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m
建议:将相同的第三方jar文件移置到tomcat/shared/lib目录下,这样可以达到减少jar 文档重复占用内存的目的。



Sun文档是这样解释的:

java.lang.OutOfMemoryError: PermGen space

The detail message PermGen space indicates that the permanent generation is full. The permanent generation is the area of the heap where class and method objects are stored. If an application loads a very large number of classes, then the size of the permanent generation might need to be increased using the -XX:MaxPermSize option.

Interned java.lang.String objects are also stored in the permanent generation. The java.lang.String class maintains a pool of strings. When the intern method is invoked, the method checks the pool to see if an equal string is already in the pool. If there is, then the intern method returns it; otherwise it adds the string to the pool. In more precise terms, the java.lang.String.intern method is used to obtain the canonical representation of the string; the result is a reference to the same class instance that would be returned if that string appeared as a literal. If an application interns a huge number of strings, the permanent generation might need to be increased from its default setting.

When this kind of error occurs, the text String.intern or ClassLoader.defineClass might appear near the top of the stack trace that is printed.

The jmap -permgen command prints statistics for the objects in the permanent generation, including information about internalized String instances. See 2.6.4 Getting Information on the Permanent Generation.

下面是某人遇到的问题:

SUN JDK+Tomcat 5.5.20运行服务的时候遇到问题,服务器跑几天后就会挂掉,并报java.lang.OutOfMemoryError: PermGen space异常。

发现很多人把问题归因于: spring,hibernate,tomcat,因为他们动态产生类,导致JVM中的permanent heap溢出 。然后解决方法众说纷纭,有人说升级 tomcat版本到最新甚至干脆不用tomcat。还有人怀疑spring的问题,在spring论坛上讨论很激烈,因为spring在AOP时使用CBLIB会动态产生很多类。

但问题是为什么这些王牌的开源会出现同一个问题呢,那么是不是更基础的原因呢?tomcat在Q&A很隐晦的回答了这一点。(Why does the memory usage increase when I redeploy a web application? Because the Classloader (and the Class objects it loaded) cannot be recycled. They are stored in the permanent heap generation by the JVM, and when you redepoy a new class loader is created, which loads another copy of all these classes. This can cause OufOfMemoryErrors eventually. )

于是有人对更基础的JVM做了检查,发现了问题的关键。原来SUN 的JVM把内存分了不同的区,其中一个就是permanent区用来存放用得非常多的类和类描述。本来SUN设计的时候认为这个区域在JVM启动的时候就固定了,但他没有想到现在动态会用得这么广泛。而且这个区域有特殊的垃圾收回机制,现在的问题是动态加载类到这个区域后,gc根本没办法回收!

对这个bug最彻底的解决办法就是不要用SUN的JDK,而改用BEA的 JRokit.



在tomcat中redeploy时出现outofmemory的错误.

可以有以下几个方面的原因:

1,使用了proxool,因为proxool内部包含了一个老版本的cglib.

2, log4j,最好不用,只用common-logging

3, 老版本的cglib,快点更新到最新版。

4,更新到最新的hibernate3.2
3、 这里以tomcat环境为例,其它WEB服务器如jboss,weblogic等是同一个道理。



二、java.lang.OutOfMemoryError: Java heap space
Heap size 设置
JVM堆的设置是指java程序运行过程中JVM可以调配使用的内存空间的设置.JVM在启动的时候会自动设置Heap size的值,
其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)是物理内存的1/4。可以利用JVM提供的-Xmn -Xms -Xmx等选项可
进行设置。Heap size 的大小是Young Generation 和Tenured Generaion 之和。
提示:在JVM中如果98%的时间是用于GC且可用的Heap size 不足2%的时候将抛出此异常信息。
提示:Heap Size 最大不要超过可用物理内存的80%,一般的要将-Xms和-Xmx选项设置为相同,而-Xmn为1/4的-Xmx值。
解决方法:手动设置Heap size
修改TOMCAT_HOME/bin/catalina.sh
在“echo "Using CATALINA_BASE:   $CATALINA_BASE"”上面加入以下行:
JAVA_OPTS="-server -Xms800m -Xmx800m   -XX:MaxNewSize=256m"

三、实例,以下给出1G内存环境下java jvm 的参数设置参考:

JAVA_OPTS="-server -Xms800m -Xmx800m  -XX:PermSize=64M -XX:MaxNewSize=256m -XX:MaxPermSize=128m -Djava.awt.headless=true "




针对Tomcat,如果Tomcat下面有多个应用,尽可能的把lib下共用的jar文件放到Tomcat的lib下,发布速度和运行速度上也有所提升。



题外话:经常看到网友抱怨tomcat的性能不如...,不稳定等,其实根据笔者几年的经验,从"互联星空“到现在的房产门户网,我们 均使用tomcat作为WEB服务器,每天访问量百万多,tomcat仍然运行良好。建议大家有问题多从自己程序入手,多看看java的DOC文档。

参考文档:http://blogs.sun.com/jonthecollector/entry/presenting_the_permanent_generation



文章出处:http://blog.csdn.net/xiaojianpitt/archive/2008/11/11/3276790.aspx



本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/chen1255/archive/2009/12/26/5082939.aspx
分享到:
评论

相关推荐

    Tomcat出现_PermGen_space解决方案

    #### 一、PermGen Space 概念解析 PermGen Space,即 Permanent Generation Space,是 JVM(Java Virtual Machine)内存的一部分,主要用于存储 Class 文件信息、静态变量、常量池以及方法元数据等。与 Heap Space ...

    JVM-整体结构原理深度解析

    - 在JDK 1.7及以前版本称为永久代(PermGen space),用于存储类信息、常量、静态变量等数据。 - 从JDK 1.8开始,方法区被移到了Metaspace,即元数据空间,这是一个本地内存区域,不再受到垃圾回收的影响。 #### ...

    深入浅出jvm虚拟机视频大全(jvm性能调优+内存模型+虚拟机原理)

    对于HotSpot虚拟机而言,这部分区域被称为“永久代”(PermGen space),而在JVM 8之后,已经被“元空间”(Metaspace)所替代,其物理内存空间不再受堆大小限制,而是由系统的实际可用内存决定。 #### 2. 堆 堆是...

    jvm参数设置

    3. **-XX:PermSize**: 设置永久代(PermGen space)的初始大小。例如,`-XX:PermSize=256m`表示永久代初始大小为256MB。 4. **-XX:MaxPermSize**: 设置永久代的最大大小。例如,`-XX:MaxPermSize=512m`表示永久代...

    JVM.pdf

    在堆内存中,有一个特殊的区域叫永久代( Perm Gen space),在较旧的JVM版本中,用于存储类元数据。在现代JVM(如Java 8及更高版本)中,这部分功能已被元空间(Metaspace)取代,它位于本地内存,以减少内存溢出...

    JVM配置资料JVM配置资料

    - **PermGen/Metaspace Overflow**:持久代/元空间溢出,通常由于过多的类或大型静态变量引起,可通过增大相应区域大小或限制类加载。 9. **JIT编译器(Just-In-Time Compiler)**: - **HotSpot** JVM包含C1和C2...

    JVM中[方法区]的所有内容-pdf

    方法区的大小可以通过JVM参数进行设置,如在JDK7及之前,使用-XX:PermSize和-XX:MaxPermSize来设定永久代的初始和最大分配空间,以防止因加载过多类信息导致的“ PermGen space”内存溢出。而从JDK8开始,HotSpot ...

    jvm 调优,对jvm参数的详细描叙

    - **PermGen Space**:永久代空间不足时,会出现`OutOfMemoryError: PermGen space`错误。 - **解决方案**:增大永久代大小,如使用`-XX:PermSize`和`-XX:MaxPermSize`。 - **Stack**:线程栈溢出,通常是因为...

    Java JVM面试题.rar

    - **元空间**:Java 8以后,常量池从 PermGen 移到了 Metaspace,避免了Full GC时的“PermGen Space” OutOfMemoryError。 10. **JVM与模块系统** - **Java 9及以后的模块化**:使用Jigsaw项目引入了模块系统,...

    JVM性能优化相关问题-面试-进阶

    在堆内存中,有一个特殊的区域称为永久代(Perm Gen space),在较早的JVM版本中用于存储类的元数据,但在现代JVM(如Java 8及以上)中,这部分已被元空间(Metaspace)取代,以减少Full GC的发生并提高性能。...

    JVM调优总结 Xms -Xmx -Xmn -Xss

    - **定义**:设置永久代(PermGen space)的最大大小。 - **示例**:`-XX:MaxPermSize=16m` 设置永久代最大为16MB。 #### 8. -XX:MaxTenuringThreshold - **定义**:设置对象晋升到老年代前的最大年龄阈值。 - **...

    java中jvm原理和实现

    3. **方法区(Method Area)**: 也称为永久代(PermGen space),用于存储已加载类的元数据信息、常量池等。这些数据在类被加载后就存在,并在整个JVM生命周期内保持不变。 4. **程序计数器(Program Counter Register)...

    三问JMM--有关JVM内存模型的PPT

    - **内存的功能划分**:主要包括方法区(Method Area)、永久代(PermGen space)、虚拟机栈(VM stack)、本地方法栈(Native Method Stack)、程序计数器(PC Register)等。 在程序执行的过程中,JVM会根据需要...

    Java虚拟机(JVM)面试题51道 pdf文档整理.zip

    10. **JVM内存溢出问题**:常见的有堆溢出(OOM: OutOfMemoryError - heap space)、 PermGen/元空间溢出、方法区溢出等,需要合理设置JVM参数并优化代码以避免。 通过掌握以上知识点,Java开发者不仅可以编写高...

    JVM学习笔记

    在JVM 8之前称为永久代(PermGen)。 - **垃圾回收机制**: - **新生代GC**:采用复制算法,将Eden区中存活的对象复制到Survivor区之一,之后清空Eden区。当Survivor区之一不足以容纳时,则对象会被提升到老年代。...

    java内存机制

    #### 三、运行时数据区的深入解析 ##### 1. 堆(Heap) - **作用**: 存储所有类实例和数组。 - **特点**: 每个Java虚拟机实例只有一个堆空间,所有线程共享此堆空间。 - **问题**: 需要解决多线程访问堆数据的同步...

    深入java 虚拟机

    常见的OOM异常有`OutOfMemoryError: Java heap space`(堆内存溢出)、`PermGen space`(永久代溢出,Java 8后已不存在)和`Metaspace`(元空间溢出)。 9. **线程模型** JVM支持多线程编程,每个线程有自己的程序...

    Core java欢迎下载

    如果Method Area空间耗尽,会出现`java.lang.OutOfMemoryError: PermGen space`异常。 - **Java Stack**:每个线程有自己的Java栈,用于存储方法调用的局部变量、操作数栈和方法返回地址。栈溢出会导致`java.lang....

Global site tag (gtag.js) - Google Analytics