在Eclipse使用tomcat运行3个项目时,老是报这个错误,以下为错误详情:

2014-5-28 13:47:41 org.apache.catalina.core.StandardWrapperValve invoke 严重: Servlet.service() for servlet dispatcher-

servlet threw exception
java.lang.OutOfMemoryError: PermGen space
at java.lang.ClassLoader.defineClass1(Native Method)
at java.lang.ClassLoader.defineClassCond(Unknown Source)
at java.lang.ClassLoader.defineClass(Unknown Source)
at java.security.SecureClassLoader.defineClass(Unknown Source)

原先就知道可以设置相应参数即可:http://www.cnblogs.com/garinzhang/archive/2013/03/20/2970901.html

尝试过之后发现依然不行,在网络上继续寻找解决办法。

方法1:修改catalina.sh(Linux)/catalina.bat(Windows):

Linux通过文本搜索找到echo "Using CATALINA_BASE:   $CATALINA_BASE",在上面加入:JAVA_OPTS=-server -XX:PermSize=64M -XX:MaxPermSize=128m

Windows通过搜索找到echo Using CATALINA_BASE:   "%CATALINA_BASE%",在上面加入:set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128m -XX:MaxPermSize=512m

此方法试过之后,异常依然出现,在更改了PermSize之后,重新启动tomcat,依然失败

方法2:还是修改catalina.sh/bat文件:

rem catalina.bat
set JAVA_OPTS=-Xms64m -Xmx256m -XX:PermSize=128m -XX:MaxNewSize=256M -XX:MaxPermSize=256m
#catalina.sh
JAVA_OPTS=
-Xms64m
-Xmx256m
-XX:PermSize=128m
-XX:MaxNewSize=256m
-XX:MaxPerSize=256m

重新启动tomcat,依然失败

方法3:在Eclipse的eclipse.ini文件最后添加如下:

-Xms256m
-Xmx512m
-XX:PermSize=512m
-XX:MaxPermSize=512m

重新启动Eclipse,依然失败

以上三个方法都是网上大部分给出的方法,想来别人肯定是实验成功的,为什么就不行呢,查看多篇文章之后,有些地方提到jvisualvm.exe这个工具,可以用来查看内存大小,最后通过以下步骤找到解决办法:

1. 使用JDK bin目录下面的工具:jvisualvm.exe(Java VisualVM),查看PermGen信息,才看出问题来,如下图红框为PermGen,旁边的tab为堆,就是所谓的Heap(如果Heap出现问题,则可以使用它来查看)

PermGen下面的三个值分别是(最小值、当前正在用的、最大值),我在Eclipse启动的时候,PermGen显示,最小值和最大值只有64M,所以很简单的溢出了,而我明明改过tomcat和eclipse的配置文件了呀,为什么还是这样呢?

2. 直接从tomcat/bin目录下去启动(不使用Eclipse的插件),发现我VisualVM里的tomcat的PermGen的最小、大值发生了改变,与先前在tomcat里设置的值相符,并且能正常启动。

这说明,前面方法1、2设置的值是对的,网上给出的方法是对的,由于我设置的PermGen值为256M,而我总共分配给JVM的才256M,所以又出现Heap溢出,这时候可以使用Visual VM清晰看出Heap溢出的情况。所以在设置的时候PermGen占的内存不能大于等于VM的占的总内存,设置为一半就差不多了

3. 此时问题很明确,Eclipse的tomcat插件肯定不是使用的tomcat安装目录下的设置,或者在eclipse被覆盖了,所以找到Eclipse的Tomcat插件设置,设置如下:

此时再通过Eclipse启动tomcat,就再也没出现这个问题了

后记:通过对Eclipse的内存使用Visual VM查看,发现方法3其实设置的是Eclipse的设置,不是tomcat的,所以以后设置不对的时候,使用Visual VM一看必知问题在哪。

参考:

http://www.cnblogs.com/xwdreamer/archive/2011/11/21/2296930.html

http://woo-program.iteye.com/blog/1243613

http://blog.sina.com.cn/s/blog_6840f82901013wk8.html

http://www.iteye.com/problems/93036

http://www.mkyong.com/tomcat/tomcat-javalangoutofmemoryerror-permgen-space/

http://hi.baidu.com/chssheng2007/item/3f8cd7e7d41ed80c8c3ea8c2

http://hi.baidu.com/ijczwiiukobnorq/item/9d6ca3c35ed80c7788ad9e66

[Java] 使用Java Visual VM寻找PermGen Space的解决办法的更多相关文章

  1. Tomcat内存溢出(java.lang.OutOfMemoryError: PermGen space)的解决办法

    Tomcat启动时报如下错误: java.lang.OutOfMemoryError: PermGen space 解决办法: 配置相关内存大小.其中按照启动tomcat的不同方式,分如下三种情况 a ...

  2. 在Eclipse中运行Jboss时出现java.lang.OutOfMemoryError:PermGen space及其解决方法

    在Eclipse中运行Jboss时出现java.lang.OutOfMemoryError:PermGen space及其解决方法 在Eclipse中运行Jboss时,时间太长可能有时候会出现java ...

  3. java.lang.OutOfMemoryError: PermGen space及其解决方法(转载)

    java.lang.OutOfMemoryError: PermGen space及其解决方法 分类: java2007-09-11 12:34 162242人阅读 评论(51) 收藏 举报 gene ...

  4. java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 错误的解决办法

    java.lang.ClassNotFoundException: oracle.jdbc.driver.OracleDriver 错误的解决办法 (2011-05-05 16:08:05) 转载▼ ...

  5. jmeter—PerfMon Metrics Collector(附java.io.IOException: Agent is unreachable via TCP错误解决办法)

    jmeter—PerfMon Metrics Collector(附java.io.IOException: Agent is unreachable via TCP错误解决办法 转自https:// ...

  6. Exception in thread "main" java.lang.UnsupportedClassVersionError: * : Unsupported major.minor version 52.0 解决办法

    Exception in thread "main" java.lang.UnsupportedClassVersionError: * : Unsupported major.m ...

  7. Scrapy安装报错 Microsoft Visual C++ 14.0 is required 解决办法

    Scrapy安装报错 Microsoft Visual C++ 14.0 is required 解决办法原因:Scrapy需要的组 twisted 需要 C++环境编译. 方法一:根据错误提示去对应 ...

  8. Eclipse中启动tomcat报错java.lang.OutOfMemoryError: PermGen space的解决方法

    有的项目引用了太多的jar包,或者反射生成了太多的类,异或有太多的常量池,就有可能会报java.lang.OutOfMemoryError: PermGen space的错误, 我们知道可以通过jvm ...

  9. [转]Tomcat启动java.lang.OutOfMemoryError: PermGen space错误解决

    原文地址:http://outofmemory.cn/java/OutOfMemoryError/outofmemoryerror-permgen-space-in-tomcat-with-eclip ...

随机推荐

  1. WCF 定制自己的签名验证逻辑

    关键点: 1. 保证在客户端设置签名. client.ClientCredentials.ClientCertificate.SetCertificate(StoreLocation.CurrentU ...

  2. HTML5之sessionStorage

    http://www.css88.com/archives/tag/sessionstorage http://blog.csdn.net/qxs965266509/article/details/1 ...

  3. ACM/ICPC 之 递归(POJ2663-完全覆盖+POJ1057(百练2775)-旧式文件结构图)

    POJ2663-完全覆盖 题解见首注释 //简单递推-三个米诺牌(3*2)为一个单位打草稿得出规律 //题意-3*n块方格能被1*2的米诺牌以多少种情况完全覆盖 //Memory 132K Time: ...

  4. 算法手记 之 数据结构(线段树详解)(POJ 3468)

    依然延续第一篇读书笔记,这一篇是基于<ACM/ICPC 算法训练教程>上关于线段树的讲解的总结和修改(这本书在线段树这里Error非常多),但是总体来说这本书关于具体算法的讲解和案例都是不 ...

  5. ffmpeg-20160506-git-bin

    ESC 退出 0 进度条开关 1 屏幕原始大小 2 屏幕1/2大小 3 屏幕1/3大小 4 屏幕1/4大小 S 下一帧 [ -2秒 ] +2秒 ; -1秒 ' +1秒 下一个帧 -> -5秒 f ...

  6. Greedy:Linear world(POJ 2674)

      Linear world 题目大意:一些人生活在线性世界中,到达线性世界两端就会消失,两个人的前进方向有两个,相遇会改变各自相遇方向,求最后一个人掉下的人的名字和时间. 其实这一题就是弹性碰撞的模 ...

  7. IOS - Objective-C NSArray和NSMutableArray的详解 使用

    原文地址:http://blog.csdn.net/totogo2010/article/details/7729377 Objective-C的数组比C++,Java的数组强大在于,NSArray保 ...

  8. Java常用工具类题库

    一.    填空题 在Java中每个Java基本类型在java.lang包中都在一个相应的包装类,把基本类型数据转换为对象,其中包装类Integer是___Number__的直接子类. 包装类Inte ...

  9. C#更新SQLServer中的TimeStamp字段(时间戳) 防止同时修改一行时覆盖更新

    C#更新SQLServer中的TimeStamp字段(时间戳) 分类: C#2012-10-24 15:10 1878人阅读 评论(0) 收藏 举报 public partial class Form ...

  10. [Android Pro] linux下查看一个文件的属性(ls,lsattr,file,stat)

    reference to : http://blog.chinaunix.net/uid-28458801-id-4615294.html 查看文件属性有多种方法,且这些方法中偏向不同,具体如下: 1 ...