才子佳人博客

我的故事我讲述

java.lang.OutOfMemoryError: Java heap space 解决方法
 
来源:xjh  编辑:xjh  2008-05-06

环境说明:linux,tomcat,mysql

异常:java.lang.OutOfMemoryError: Java heap space

问题陈述:

tomcat服务器运行一段时间后,tomcat控制台报错:

java.lang.outOfMemoryError,java.lang.outOfMemoryError

然后tomcat服务死掉,只有重启tomcat才能恢复服务

分析:

1)java虚拟机jvm内存过小

2)程序不严密,产生太多的垃圾

解决方法:

没有足够的内存分配给实际运行的应用程序?两种选择:

1)使用-Xmx参数增加堆的最大使用内存; 

2)使用更小的集合/缓冲区/表空间/对象...,以减少所需要的内存总量,及时释放不使用的对象,也就是说,调整对象大小,重新设计、修改应用程序。

针对第一个原因

jvm虚拟机的默认Heap大小是64M,可以通过设置其最大和最小值来实现。设置的方法主要是几个.

1.可以在windows 更改系统环境变量
加上JAVA_OPTS=-Xms64m -Xmx512m

2.如果用的tomcat,在windows下,可以在

C: /tomcat5.5.9/incatalina.bat 中加上:

set JAVA_OPTS=-Xms64m -Xmx256m

位置在: rem Guess CATALINA_HOME if not defined 这行的下面加合适.

3.如果是linux系统(测试通过)
编辑 在{tomcat_home}/bin/catalina.sh文件,如
vi /opt/apache-tomcat-6.0.14/bin/catalina.sh

# JAVA_OPTS (Optional) Java runtime options used when the "start",
# "stop", or "run" command is executed.
下加入
export JAVA_OPTS="-server -Xms512m -Xmx1024m"

注意是半角双引号,保存文件并修改catalina.sh 文件为可执行,

chmod +x catalina.sh

重新启动tomcat服务器

注意:

1)Application Server Xms setting should not be set equal to the Xmx setting.

2)另外Xmx作为允许jvm使用的最大内存数量,不应该超过物理内存的90%。

3)若重启tomcat 时出现如下错误:

[root@linuxserver bin]# sh shutdown.sh
Cannot find ./catalina.sh
This file is needed to run this program

则需要添加sh脚本文件可执行权限,如下:

chmod +x /../apache-tomcat6/bin/*.sh

针对第二个原因:

由于jvm产生的垃圾是由我们所写的代码产生的,质量好的代码产生的垃圾少,相反就会产生很多垃圾。由于jvm的最大内存不能无限增大,故增大jvm的最大内存应该是在代码已经达到很优化时才实施的,所以优化程序才是我们最先要做的。

如何优化程序:

第一,避免死循环。仔细检查程序,防止出现死循环,这是比较容易检查的。

第二,可以适当手动回收垃圾 ,如调用方法System.gc()

第三,应该及时释放各种资源:内存, 数据库的各种连接。 如置对象为null,关闭数据库连接。

参考:

http://blog.csdn.net/shaokun305/archive/2007/10/25/1843367.aspx

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

http://sundoctor.bokee.com/viewdiary.177198422.html

http://www-1.ibm.com/support/docview.wss?uid=swg21160795

Thinking in Java third edition

原始错误日志:

type Exception report

message

description The server encountered an internal error () that prevented it from fulfilling this request.

exception

org.apache.jasper.JasperException: javax.servlet.ServletException: java.lang.OutOfMemoryError: Java heap space

org.apache.jasper.servlet.JspServletWrapper.handleJspException(JspServletWrapper.java:496)

org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:408)

org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320)

org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266)

javax.servlet.http.HttpServlet.service(HttpServlet.java:803)


root cause

javax.servlet.ServletException: java.lang.OutOfMemoryError: Java heap space

org.apache.jasper.runtime.PageContextImpl.doHandlePageException(PageContextImpl.java:855)

org.apache.jasper.runtime.PageContextImpl.handlePageException(PageContextImpl.java:784)

org.apache.jsp.index_jsp._jspService(index_jsp.java:925)

org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)

javax.servlet.http.HttpServlet.service(HttpServlet.java:803)

org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:384)

org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:320)

org.apache.jasper.servlet.JspServlet.service(JspServlet.java:266)

javax.servlet.http.HttpServlet.service(HttpServlet.java:803)


root cause

java.lang.OutOfMemoryError: Java heap space


note The full stack trace of the root cause is available in the Apache Tomcat/6.0.10 logs.

Apache Tomcat/6.0.10

设置虚拟机参数后查看进程状态:

[root@linuxserver bin]# ps -aux|grep java
Warning: bad syntax, perhaps a bogus -? See /usr/share/doc/procps-3.2.3/FAQ
root 4647 4.1 9.4 1228952 98016 ? Sl 10:27 0:19 /usr/java/jdk1.6.0/jre/bin/java -server -Xms512m -Xmx1024m -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file=/app/local/tomcat6.0/conf/logging.properties -Djava.endorsed.dirs=/app/local/tomcat6.0/endorsed -classpath :/app/local/tomcat6.0/bin/bootstrap.jar:/app/local/tomcat6.0/bin/commons-logging-api.jar -Dcatalina.base=/app/local/tomcat6.0 -Dcatalina.home=/app/local/tomcat6.0 -Djava.io.tmpdir=/app/local/tomcat6.0/temp org.apache.catalina.startup.Bootstrap start
root 4793 0.0 0.0 5516 696 pts/1 S+ 10:35 0:00 grep java


分类:网络日志| 查看评论
相关文章
文章点击排行
本年度文章点击排行
发表评论:
  • 昵称: *
  • 邮箱: *
  • 网址:
  • 评论:(最多100字)
  • 验证码: