java string 内存泄漏_String内存溢出异常(错误)可能的原因及解决方式

当中PermGen

space是Permanent Generationspace的简写,表示内存的永久保存区域,这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被放到PermGenspace中,它和存放类实例(Instance)的Heap区域不同,GC(Garbage

Collection)不会在主程序执行期对PermGen space进行清理。所以假设你的应用中有非常多CLASS的话,就非常可能出现PermGen space错误。

内容简单介绍:

第一部分:原理解析(为什么为出现这种原因)

第二部分:实际应用分析及解决方式參考

第三部分:安装版的Tomcat如何设置JAVA_OPTS

第一部分:原理解析:

1、String事实上是没有限制的。而是当String太大了,超过JVM的自身的内存后会抛出java.lang.OutOfMemoryError错误,String是没有长度限制的,而是有JVM的内存限制了String的长度。

同一时候说明,并不会抛出不论什么Exception而仅仅会抛出Error。

OutMemoryError表明程序的设计差。或者遇到了超出编程人员所预想的大批量的数据。

无论哪种情况,都仅仅有以下这几种解决的方法。它们是:

A、设计人员又一次设计程序。不致使程序一次加载全部的数据。

B、数据能够切割成更小的块。

C、能够为程序分配很多其它的内存。

D、为Java虚拟机提供很多其它的内存。

2、一般都是发生在开启大型档案或跟数据库一次载入太多的数据,造成 Out Of MemoryError的状况,这时就大概要计算一下数据量的最大值是多少。而且设定所需最小及最大的内存空间值。还有一种状况平时比較难查觉。

就是 Servlet或 JSP的 Container 突然同一时候上线人数爆增,也相对造成内存需求不足,所以也必需要计算出程序所需的数据量*同一时候上线人数,来设定内存的需求量。

(假设要有最佳化的值。最好是配合 gc 做调校)

3、当 CPU速度愈快,内存的最小需求量也就必需愈大。原因是 CPU 愈快,短时间内能处理的数据量也就愈大,所以在 java 做 GC 之前,可能已经内存已经消耗完了。所以 CPU 的速度也是内存初始需求量的重要因素之中的一个。

解决方法:

改动JAVA_OPTS="-Xms1024m-Xmx1024m" 或更大,依据系统内存情况

jsp开发中有关java.lang.OutOfMemoryError的产生及解决方法

第二部分:实际应用场景及解决方式參考(例如以下是server版——解压缩版本号):

预准备(各种环境中文件的位置)

【Windows】在catalina.bat的第一行添加:

set JAVA_OPTS=-Xms512m -Xmx900m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=256m【非Windows】在catalina.sh的第一行添加:JAVA_OPTS=-Xms512m -Xmx900m -XX:PermSize=128M -XX:MaxNewSize=256m -XX:MaxPermSize=256m

一、java.lang.OutOfMemoryError: PermGenspace

PermGen space的全称是PermanentGeneration space,是指内存的永久保存区域,

这块内存主要是被JVM存放Class和Meta信息的,Class在被Loader时就会被放到PermGen space中,它和存放类实例(Instance)的Heap区域不同,GC(Garbage Collection)不会在主程序执行期对PermGen

space进行清理,所以假设你的应用中有非常多CLASS的话,就非常可能出现PermGenspace错误,这样的错误常见在webserver对JSP进行precompile的时候。假设你的WEB APP下都用了大量的第三方jar, 其大小超过了jvm默认的大小(4M)那么就会产生此错误信息了。

改动TOMCAT_HOME/bin/catalina.sh在“echo "Using CATALINA_BASE:  $CATALINA_BASE"”上面增加下面行:

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

建议:将同样的第三方jar文件移置到tomcat/shared/lib文件夹下,这样能够达到降低jar 文档反复占用内存的目的。

二、java.lang.OutOfMemoryError:Java heap spaceHeap 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 "UsingCATALINA_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 "

大家都知道,JAVA程序启动时都会JVM都会分配一个初始内存和最大内存给这个应用程序。

这个初始内存和最大内存在一定程度都会影响程序的性能。比方说在应用程序用到最大内存的时候,JVM是要先去做垃圾回收的动作,释放被占用的一些内存。

所以想调整Tomcat的启动时初始内存和最大内存就须要向JVM声明。一般的JAVA程序在执行都能够通过中-Xms -Xmx来调整应用程序的初始内存和最大内存:

如:java -Xms64m    -Xmx128m    a.jar.

tomcat的启动程序是包装过的,不能直接使用java -X..... tomcat.*来改变内存的设置。

在Tomcat在改变这个设置有两种方法:1.就须要在环境变量中加上TOMCAT_OPTS, CATALINA_OPTS两个属性。

如 SET    CATALINA_OPTS= -Xms64m -Xmx512m;

ms是最小的。mx是最大。64m, 512m各自是指内存的容量.

2.      改动Catalina.bat文件

在166行“rem Execute Java with the applicable properties ”下面每行

%_EXECJAVA% %JAVA_OPTS% %CATALINA_OPTS% %DEBUG_OPTS%-Djava.endorsed.dirs="%JAVA_ENDORSED_DIRS%" -classpath"%CLASSPATH%" -Dcatalina.base="%CATALINA_BASE%"-Dcatalina.home="%CATALINA_HOME%"-Djava.io.tmpdir="%CATALINA_TMPDIR%" %MAINCLASS% %CMD_LINE_ARGS%%ACTION%

中的%CATALINA_OPTS% 替换成-Xms64m-Xmx512m

第三部分:假设是安装版的tomcat如何设置JAVA_OPTS

JAVA_OPTS="-Xms128M-Xmx512M -XX:PermSize=128M -XX:MaxPermSize=512M"

tomcat假设是通过windows服务启动,运行的是bin\tomcat.exe.他读取注冊表中的值,而不是catalina.bat的设置.

解决的方法:改动注冊表HKEY_LOCAL_MACHINE\SOFTWARE\Apache Software Foundation\Procrun2.0\Tomcat6\Parameters\JavaOptions原值为

-Dcatalina.home=E:\Tomcat 6.0

-Dcatalina.base=E:\Tomcat 6.0

-Djava.endorsed.dirs=E:\Tomcat 6.0\common\endorsed

-Djava.io.tmpdir=E:\Tomcat 6.0\temp

-Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager

-Djava.util.logging.config.file=E:\Tomcat6.0\conf\logging.properties

在后面添加就可以:

-Xms128M

-Xmx512M

-XX:PermSize=128M

-XX:MaxPermSize=512M

必需要分行写。

终于效果例如以下:(细节注解:将对应的信息增加Java Options输入框的后面就可以)

SouthEast

有时在ECLIPSE中启动TOMCAT会出现内存溢出和转换错误等莫名奇异的错误,这些非常有可能是内存不够引起的。这时能够在设置中找到Server然后找到Tomcat找到相应的版本号。

方法一:永久设置JVM对应的參数值:

通过Windows下的Preferences找到Tomcat中的JVM Settings中的Append to JVMParameters进行对应的參数设置:

-Xms128m -Xmx512m  -XX:PermSize=256M-XX:MaxNewSize=128m -XX:MaxPermSize=512m

例如以下图所看到的:

955edbe47ed3324fb66974618d0d5cb0.png

方法二:暂时设置对应的參数——在eclipse中进行例如以下步骤设置:

1、点击eclipse上的debug图标旁边的下拉箭头

2、然后选择Debug  Configurations,

3、系统弹出设置tomcat配置页面。在Argument中末尾加入參数中的VM arguments中追加:

-Xms256M-Xmx512M -XX:PermSize=256m -XX:MaxPermSize=512m

參数的意思

-vmargs:说明后面是VM的參数

-Xms40m:虚拟机占用系统的最小内存

-Xmx256m:虚拟机占用系统的最大内存

-XX:PermSize:最小栈内存大小。

一般报内存不足时,都是说这个太小,堆空间剩余小于5%就会警告,建议把这个略微设大一点,只是要视自己机器内存大小来设置

-XX:MaxPermSize:最大栈内存大小。

这个也适当大些

-Xmx512M的5%为25.6M。理论上要求-Xmx的数值与-XX:MaxPermSize必须大于25.6M

SouthEast

參考文献:

http://my.oschina.net/colorleaf/blog/175581

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值