Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >java.lang.OutOfMemoryError: PermGen spacejava.lang.OutOfMemoryError: PermGen space

java.lang.OutOfMemoryError: PermGen spacejava.lang.OutOfMemoryError: PermGen space

作者头像
一个会写诗的程序员
发布于 2018-08-17 06:23:40
发布于 2018-08-17 06:23:40
80200
代码可运行
举报
运行总次数:0
代码可运行

java.lang.OutOfMemoryError: PermGen space

Exception: java.lang.OutOfMemoryError thrown from the UncaughtExceptionHandler

-Xms800m -Xmx1024m -XX:PermSize=512M -XX:MaxNewSize=256m -XX:MaxPermSize=512m -Dantx.properties=/Users/jack/aipqa/swork.info/swork.info.server/antx.properties -Dpandora.location=/Users/jack/soft/taobao-tomcat-7.0.68/deploy/taobao-hsf.sar

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
22:09:22.597 java.lang.ThreadGroup uncaughtException
System.err: Exception in thread "RMI TCP Connection(idle)" 
java.lang.OutOfMemoryError: PermGen space[2017-10-19 10:09:22,790] Artifact swork.info.server:war exploded: Error during artifact deployment. See server log for details.
2017-10-19 22:09:23.690 java.lang.ThreadGroup uncaughtException
System.err: Exception in thread "RMI TCP Connection(idle)" 
java.lang.OutOfMemoryError: PermGen space22:09:44.815 [JmonitorClient-CheckThread Pool [Thread-1]] ERROR c.a.a.jmonitor.client.JmonitorClient - Connection refused
2017-10-19 22:09:59.284 java.lang.ThreadGroup uncaughtException
System.err: Exception in thread "RMI TCP Connection(idle)" 
java.lang.OutOfMemoryError: PermGen space

导致OutOfMemoryError异常的常见原因有以下几种:

内存中加载的数据量过于庞大,如一次从数据库取出过多数据; 集合类中有对对象的引用,使用完后未清空,使得JVM不能回收; 代码中存在死循环或循环产生过多重复的对象实体; 使用的第三方软件中的BUG; 启动参数内存值设定的过小; 此错误常见的错误提示:

tomcat:java.lang.OutOfMemoryError: PermGen space tomcat:java.lang.OutOfMemoryError: Java heap space weblogic:Root cause of ServletException java.lang.OutOfMemoryError resin:java.lang.OutOfMemoryError java:java.lang.OutOfMemoryError 解决java.lang.OutOfMemoryError的方法有如下几种:

一、增加jvm的内存大小。

方法有:

1)在执行某个class文件时候,可以使用java -Xmx256M aa.class来设置运行aa.class时jvm所允许占用的最大内存为256M。

2)对tomcat容器,可以在启动时对jvm设置内存限度。对tomcat,可以在catalina.bat中添加:

set CATALINA_OPTS=-Xms128M -Xmx256M set JAVA_OPTS=-Xms128M -Xmx256M 或者把%CATALINA_OPTS%和%JAVA_OPTS%代替为-Xms128M -Xmx256M

3)对resin容器,同样可以在启动时对jvm设置内存限度。在bin文件夹下创建一个startup.bat文件,内容如下:

@echo off call "httpd.exe" "-Xms128M" "-Xmx256M" :end 其中"-Xms128M"为最小内存,"-Xmx256M"为最大内存。

二、 优化程序,释放垃圾。

主要包括避免死循环,应该及时释放种资源:内存, 数据库的各种连接,防止一次载入太多的数据。导致java.lang.OutOfMemoryError的根本原因是程序不健壮。因此,从根本上解决Java内存溢出的唯一方法就是修改程序,及时地释放没用的对象,释放内存空间。 遇到该错误的时候要仔细检查程序,嘿嘿,遇多一次这种问题之后,以后写程序就会小心多了。

Java代码导致OutOfMemoryError错误的解决:

需要重点排查以下几点:

检查代码中是否有死循环或递归调用。 检查是否有大循环重复产生新对象实体。 检查对数据库查询中,是否有一次获得全部数据的查询。一般来说,如果一次取十万条记录到内存,就可能引起内存溢出。这个问题比较隐蔽,在上线前,数据库中数据较少,不容易出问题,上线后,数据库中数据多了,一次查询就有可能引起内存溢出。因此对于数据库查询尽量采用分页的方式查询。 检查List、MAP等集合对象是否有使用完后,未清除的问题。List、MAP等集合对象会始终存有对对象的引用,使得这些对象不能被GC回收。 tomcat中java.lang.OutOfMemoryError: PermGen space异常处理

PermGen space的全称是Permanent Generation space,是指内存的永久保存区域,这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被放到PermGen space中, 它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序运行期对PermGen space进行清理,所以如果你的应用中有很多CLASS的话,就很可能出现PermGen space错误, 这种错误常见在web服务器对JSP进行pre compile的时候。如果你的WEB APP下都用了大量的第三方jar, 其大小超过了jvm默认的大小(4M)那么就会产生此错误信息了。 解决方法: 手动设置MaxPermSize大小修改TOMCAT_HOME/bin/catalina.sh在

echo "Using CATALINA_BASE: $CATALINA_BASE" 上面加入以下行:

JAVA_OPTS="-server -XX:PermSize=64M -XX:MaxPermSize=128m

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017.10.20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
java.lang.OutOfMemoryError: Java heap space错误及处理办法(收集整理、转)
下面是从网上找到的关于堆空间溢出的错误解决的方法: java.lang.OutOfMemoryError: Java heap space ===================================================
全栈程序员站长
2022/07/13
7K0
spark出现GC overhead limit exceeded和java heap space
    spark执行任务时出现java.lang.OutOfMemoryError: GC overhead limit exceeded和java.lang.OutOfMemoryError: java heap space 最直接的解决方式就是在spark-env.sh中将下面两个参数调节的尽量大     export SPARK_EXECUTOR_MEMORY=6000M     export SPARK_DRIVER_MEMORY=7000M 注意,此两个参数设置需要注意大小顺序:     SPA
闵开慧
2018/04/02
4.9K0
tomcat内存溢出解决,java.lang.OutOfMemoryError: PermGen space
今天遇到了一个java.lang.OutOfMemoryError: PermGen space异常问题,一直解决不了,根据网上修改了tomcat的配置文件,但是还是解决不了,最后是通过如下方式解决的,解决步骤如下:eclipse–》 window–》show view –》server–》双击图一将会跳转到图二界面–》双击图二的Open launch configuration将跳转到图三–》在图三的Arguments的VM arguments顶行加上“-Xmx1024m -Xms512m -Xmn256m -XX:MaxPermSize=256m”(大小自己可以调),然后重启tomcat,问题解决。
全栈程序员站长
2021/04/07
7310
java heap space 什么意思_java heap space是什么意思?
因为程序要从数据读取近10W行记录处理,当读到9W的时候就出现 java.lang.OutOfMemoryError: Java heap space 这样的错误。
全栈程序员站长
2022/09/08
3.3K0
java heap space 什么意思_java heap space是什么意思?
tomcat内存溢出问题记录
问题说明: 公司内网环境中部署的jenkins代码发版平台突然不能访问了,查看tomcat的catalina.out日志发现报错如下: [root@redmine logs]# tail -f /srv/apache-tomcat-7.0.67/logs/catalina.out ...... Exception in thread "http-bio-8080-exec-5" java.lang.OutOfMemoryError: PermGen space Exception in thread "ht
洗尽了浮华
2018/01/23
1.6K0
Tomcat报错—Tomcat内存溢出及大小调整
本文记录一些常见的Tomcat经常出现的内存溢出问题,在查询大量数据和加载jar包出现异常。一般JVM内存溢出(OOM),分为堆内存溢出和PermGen区内存溢出:
全栈程序员站长
2022/07/19
2.7K0
OutOfMemory及其解决方法「建议收藏」
1、java.lang.OutOfMemoryError: PermGen space
全栈程序员站长
2022/07/25
10.9K0
Xms Xmx PermSize MaxPermSize 区别
1.参数的含义 -vmargs -Xms128M -Xmx512M -XX:PermSize=64M -XX:MaxPermSize=128M -vmargs 说明后面是VM的参数,所以后面的其实都是JVM的参数了 -Xms128m JVM初始分配的堆内存 -Xmx512m JVM最大允许分配的堆内存,按需分配 -XX:PermSize=64M JVM初始分配的非堆内存 -XX:MaxPermSize=128M JVM最大允许分配的非堆内存,按需分配
流柯
2018/08/30
4K0
Java企业微信开发_12_异常:java.lang.OutOfMemoryError: Java heap space
1.java.lang.OutOfMemoryError: Java heap space解决方法 (有问题咨询加微信)
shirayner
2018/08/10
5640
Jenkins优化--修改 JVM 的内存配置
Jenkins 启动方式有两种方式,一种是以 Jdk Jar 方式运行,一种是将 War 包放在 Tomcat 容器下运行。不管何种方式运行,都会存在一个问题就是,默认 JVM 内存分配太少,导致启动或者运行一段时间后内存溢出报错java.lang.OutOfMemoryError: PermGen space。所以,需要在启动前修改 JVM 内存配置。以 Tomcat 容器方式启动 Jenkins 为例配置如下:
陈不成i
2021/06/01
9.3K0
Java_异常_05_ OutOfMemoryError: Java heap space
修改 TOMCAT_HOME/bin/catalina.sh,在  echo "Using CATALINA_BASE:   $CATALINA_BASE"  上面加入以下行:
shirayner
2018/08/10
3120
Java_异常_05_ OutOfMemoryError: Java heap space
开发问题小结
这几天开发的过程中,碰见了一些问题,有些是属于常识问题,知道了记住了,下次就不会犯错,有些是属于知识模糊,需要理解,在此总结记录。
bisal
2019/01/30
4840
GeoServer发布地图服务
最近要利用GIS服务器软件发布一些地图服务,商业的软件(比如ArcGIS Server肯定是用不起的),最后在开源GIS软件GeoServer和MapServer中选择了GeoServer。 下面简单说说如果使用,给初始GeoServer的朋友一点点帮助!愿他们不走我走过的弯路,哈哈!
卡尔曼和玻尔兹曼谁曼
2019/01/22
3.6K0
GeoServer发布地图服务
皕杰报表之关于tomcat启动问题
更改 web项目WEB-INF\resources下的Congfig.xml里的 <characterEncode>UTF-8</characterEncode> 更改jsp中编码格式为utf-8
用户10133222
2022/11/03
2630
java web中的Exception in thread "ContainerBackgroundProcessor[StandardEngine[Catalina]]" java.lang.Out
E | hongtenzone@foxmail.com  B | http://www.cnblogs.com/hongten
Hongten
2018/09/13
7250
java web中的Exception in thread "ContainerBackgroundProcessor[StandardEngine[Catalina]]" java.lang.Out
java常见的几种内存溢出和解决方案
项目组最近在开发中经常会出现一些意想不到的内存溢出问题。下面我就说说我们常见的几种内存溢出吧! 1.JVM Heap(堆)溢出:java.lang.OutOfMemoryError: Java heap space JVM在启动的时候会自动设置JVM Heap的值, 可以利用JVM提供的-Xmn -Xms -Xmx等选项可进行设置。Heap的大小是Young Generation 和Tenured Generaion 之和。在JVM中如果98%的时间是用于GC,且可用的Heap size 不足2%的时候将抛出此异常信息。 解决方法:手动设置JVM Heap(堆)的大小。 2.PermGen space溢出: java.lang.OutOfMemoryError: PermGen space PermGen space的全称是Permanent Generation space,是指内存的永久保存区域。为什么会内存溢出,这是由于这块内存主要是被JVM存放Class和Meta信息的,Class在被Load的时候被放入PermGen space区域,它和存放Instance的Heap区域不同,sun的 GC不会在主程序运行期对PermGen space进行清理,所以如果你的APP会载入很多CLASS的话,就很可能出现PermGen space溢出。一般发生在程序的启动阶段。 解决方法: 通过-XX:PermSize和-XX:MaxPermSize设置永久代大小即可。 3.栈溢出: java.lang.StackOverflowError : Thread Stack space 栈溢出了,JVM依然是采用栈式的虚拟机,这个和C和Pascal都是一样的。函数的调用过程都体现在堆栈和退栈上了。调用构造函数的 “层”太多了,以致于把栈区溢出了。 通常来讲,一般栈区远远小于堆区的,因为函数调用过程往往不会多于上千层,而即便每个函数调用需要 1K的空间(这个大约相当于在一个C函数内声明了256个int类型的变量),那么栈区也不过是需要1MB的空间。通常栈的大小是1-2MB的。通俗一点讲就是单线程的程序需要的内存太大了。 通常递归也不要递归的层次过多,很容易溢出。 解决方法:1:修改程序。2:通过 -Xss: 来设置每个线程的Stack大小即可。 4.but has failed to stop it. This is very likely to create a memory leak. 这一般是启动程序时一些定时器或其他正在操作的线程还没有停掉造成的。 解决方法:实现ServletContextListener的监听,在contextDestroyed方法中进行关闭。 5. 所以Server容器启动的时候我们经常关心和设置JVM的几个参数如下: -Xms:java Heap初始大小, 默认是物理内存的1/64。 -Xmx:ava Heap最大值,不可超过物理内存。 -Xmn:young generation的heap大小,一般设置为Xmx的3、4分之一 。增大年轻代后,将会减小年老代大小,可以根据监控合理设置。 -Xss:每个线程的Stack大小,而最佳值应该是128K,默认值好像是512k。 -XX:PermSize:设定内存的永久保存区初始大小,缺省值为64M。 -XX:MaxPermSize:设定内存的永久保存区最大大小,缺省值为64M。 -XX:SurvivorRatio:Eden区与Survivor区的大小比值,设置为8,则两个Survivor区与一个Eden区的比值为2:8,一个Survivor区占整个年轻代的1/10 -XX:+UseParallelGC:F年轻代使用并发收集,而年老代仍旧使用串行收集. -XX:+UseParNewGC:设置年轻代为并行收集,JDK5.0以上,JVM会根据系统配置自行设置,所无需再设置此值。 -XX:ParallelGCThreads:并行收集器的线程数,值最好配置与处理器数目相等 同样适用于CMS。 -XX:+UseParallelOldGC:年老代垃圾收集方式为并行收集(Parallel Compacting)。 -XX:MaxGCPauseMillis:每次年轻代垃圾回收的最长时间(最大暂停时间),如果无法满足此时间,JVM会自动调整年轻代大小,以满足此值。 -XX:+ScavengeBeforeFullGC:Full GC前调用YGC,默认是true。
业余草
2019/01/21
2K0
tomcat OutOfMemoryError
Exception in thread "Timer-1" java.lang.OutOfMemoryError: PermGen space
阳光岛主
2019/02/19
1.2K0
tomcat OutOfMemoryError
java中三种常见内存溢出错误的处理方法
转载自http://blog.csdn.net/zmken497300/article/details/52496189
allsmallpig
2021/02/25
1.1K0
OutOfMemoryError: GC Overhead Limit Exceeded错误解析
简单地说,Garbage Collection (GC)就是JVM回收不再使用的对象,释放内存的过程。GC Overhead Limit Exceeded error是java.lang.OutOfMemoryError家族的一员,表示JVM内存被耗尽。接下来看看引起java.lang.OutOfMemoryError: GC Overhead Limit Exceeded错误的原因是什么,以及如何解决这个错误。
九州暮云
2019/08/21
20.9K0
Tomcat内存设置详解
1. java.lang.OutOfMemoryError: Java heap space ----JVM Heap(堆)溢出 JVM在启动的时候会自动设置JVM Heap的值,其初始空间(即-Xms)是物理内存的1/64,最大空间(-Xmx)不可超过物理内存。
allsmallpig
2021/02/25
4.5K0
相关推荐
java.lang.OutOfMemoryError: Java heap space错误及处理办法(收集整理、转)
更多 >
领券
💥开发者 MCP广场重磅上线!
精选全网热门MCP server,让你的AI更好用 🚀
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验