Tomcat内存不释放是什么原因
通过yourkitjavaprofiler8.0内存测试,实际使用内存只有100M左右,垃圾回收基本正常。但是为什么通过任务管理器看到的TOMCAT实际使用的内存却有55...
通过yourkit java profiler 8.0内存测试,实际使用内存只有100M左右,垃圾回收基本正常。但是为什么通过任务管理器看到的TOMCAT实际使用的内存却有550M,似乎TOMCAT并没有释放GC已经回收的内存,请问这是怎么回事,如何解决(解决问题加分)
展开
推荐于2017-05-21
展开全部
1.在java中虽然有垃圾回收器,但是对rs等通过jdbc访问数据库的所产生的垃圾,它并不回收!
2.是否是循环套接层数太多导致资源得不到释放,或者存在死循环,后者的可能性恨大。
3.Tomcat 不支持EJB组件的开发,做j2ee项目时,最好还是用weblogic服务,而且在做基本的sql语句时,最好用连接池,不要多用jdbc,odbc桥,因为在建立连接时最耗时间
解决方法是让tomcat自己管理内存,在startup.bat的@echo off下面添加以下代码:
set JAVA_OPTS=%JAVA_OPTS% -Dcom.sun.management.jmxremote.port=1090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file="%CATALINA_HOME%\conf\logging.properties"
然后再启动startup.bat,tomcat就会自己管理内存了.
2.是否是循环套接层数太多导致资源得不到释放,或者存在死循环,后者的可能性恨大。
3.Tomcat 不支持EJB组件的开发,做j2ee项目时,最好还是用weblogic服务,而且在做基本的sql语句时,最好用连接池,不要多用jdbc,odbc桥,因为在建立连接时最耗时间
解决方法是让tomcat自己管理内存,在startup.bat的@echo off下面添加以下代码:
set JAVA_OPTS=%JAVA_OPTS% -Dcom.sun.management.jmxremote.port=1090 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.util.logging.manager=org.apache.juli.ClassLoaderLogManager -Djava.util.logging.config.file="%CATALINA_HOME%\conf\logging.properties"
然后再启动startup.bat,tomcat就会自己管理内存了.
2013-05-28
展开全部
jvm认为那是系统分给他的内存,通常没有必要释放。
java虚拟机启动的时候,设定较小的xms和xmx,但这样一旦应用程序过大,就有可能发生内存溢出错误。
java虚拟机启动的时候,设定较小的xms和xmx,但这样一旦应用程序过大,就有可能发生内存溢出错误。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
jvm认为那是系统分给他的内存,通常没有必要释放。
java虚拟机启动的时候,设定较小的xms和xmx,但这样一旦应用程序过大,就有可能发生内存溢出错误。
java虚拟机启动的时候,设定较小的xms和xmx,但这样一旦应用程序过大,就有可能发生内存溢出错误。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询