java.lang.OutOfMemoryError: Java heap space
异常: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.9incatalina.bat 中加上:
set JAVA_OPTS=-Xms64m -Xmx256m
位置在: rem Guess CATALINA_HOME if not defined 这行的下面加合适.
注意:在apache tomcat6.0版本下找不到上述这个文件,可以打开配置界面,选择java修改初始化内存和最大内存参数如下:
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
http://www.talented.com.cn/archives/2008/5/20080506161402.html
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