java.lang.OutOfMemoryError: Java heap space + myeclipse中分配tomcat启动时所占内存大小(转)

原本不打算转贴的,可今天这个问题困扰了我好几个钟头,所以还是记到这里,以备查看

------------下面是转贴部分------------------

//首先检查程序有没有限入死循环

这个问题主要还是由这个问题 java.lang.outofmemoryerror: java heap space 引起的。第一次出现这样的的问题以后,引发了其他的问题。在网上一查可能是java的堆栈设置太小的原因。

跟据网上的答案大致有这两种解决方法:

1、设置环境变量

set java_opts= -xms32m -xmx512m

可以根据自己机器的内存进行更改。

2、java -xms32m -xmx800m classname

就是在执行java类文件时加上这个参数,其中classname是需要执行的确类名。(包括包名)

这个解决问题了。而且执行的速度比没有设置的时候快很多。

如果在测试的时候可能会用eclispe 这时候就需要在eclipse ->run -arguments 中的vm arguments 中输入-xms32m -xmx800m这个参数就可以了。

后来在eclilpse中修改了启动参数,在vm arguments 加入了-xms32m -xmx800m,问题解决。

一、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

建议:将相同的第三方jar文件移置到tomcat/shared/lib目录下,这样可以达到减少jar 文档重复占用内存的目的。

二、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 "

很大的web工程,用tomcat默认分配的内存空间无法启动,如果不是在myeclipse中启动tomcat可以对tomcat这样设置:

tomcat_home\bin\catalina.bat 中添加这样一句话:

set java_opts= -xmx1024m -xms512m -xx:maxpermsize=256m

如果要在myeclipse中启动,上述的修改就不起作用了,可如下设置:

myeclipse->preferences->myeclipse->servers->tomcat->tomcat×.×->jdk面板中的

optional java vm arguments中添加:-xmx1024m -xms512m -xx:maxpermsize=256m

-------------------------------转贴结束-----------------------------

我使用的服务方式的tomcat,内存2g,我在configure tomcat-》java-》java options中的参数设置是:

-xms500m

-xmx1024m

-xx:permsize=64m

-xx:maxpermsize=256m

-xx:reservedcodecachesize=48m

-duser.timezone=gmt+08


======================================================
在最后,我邀请大家参加新浪APP,就是新浪免费送大家的一个空间,支持PHP+MySql,免费二级域名,免费域名绑定 这个是我邀请的地址,您通过这个链接注册即为我的好友,并获赠云豆500个,价值5元哦!短网址是http://t.cn/SXOiLh我创建的小站每天访客已经达到2000+了,每天挂广告赚50+元哦,呵呵,饭钱不愁了,\(^o^)/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
java.lang.OutOfMemoryError: Java heap spaceJava程序在运行过程遇到的一种内存溢出错误。它表示Java堆内存不足以容纳程序所需的对象。当程序需要创建新的对象时,但是堆内存已经被满时,就会抛出这个错误。 解决这个问题的方法有以下几种: 1. 增加堆内存大小:可以通过修改JVM的启动参数来增加堆内存的大小。可以使用-Xmx参数来指定最大堆内存大小,例如-Xmx2g表示将最大堆内存设置为2GB。 2. 优化程序内存使用:可以通过检查程序是否存在内存泄漏或者不必要的对象引用来优化内存使用。确保及时释放不再使用的对象,避免创建过多的临时对象。 3. 使用更高效的数据结构:如果程序使用了大量的数据结构,可以考虑使用更高效的数据结构来减少内存用。例如,使用HashMap代替ArrayList可以减少内存用。 4. 分析内存使用情况:可以使用工具来分析程序的内存使用情况,找出内存用较大的对象或者代码段,并进行优化。常用的工具有jvisualvm、jprofiler等。 5. 调整垃圾回收策略:可以通过调整垃圾回收策略来减少内存用。可以使用不同的垃圾回收器,调整垃圾回收的参数等。 下面是一个示例代码,演示如何增加堆内存大小来解决java.lang.OutOfMemoryError: Java heap space错误: ```java public class HeapSpaceDemo { public static void main(String[] args) { // 创建一个大对象,用大量内存 byte[] bigObject = new byte[1024 * 1024 * 1024]; // 打印对象的大小 System.out.println("Object size: " + bigObject.length); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值