Tomcat JVM调优有感

最近在做一个社交类网站,采用的技术框架是Spring+Struts2+Ibatis,数据库是的MySql5.0,web服务器是tomcat6.0,常见的技术基本上都用到了,像存储过程,lucence,quartz,jms等等。Spring框架有一个很重要的名词就是“动态代理”,在系统运行过程中会产生很多代理类实例,而这些代理对象是不能被GC自动释放的,所以在运行过程中,tomcat经常报java.lang.OutOfMemoryError:PermGen Space和java.lang.OutOfMemoryError:Heap Space的异常,经常是几个操作之后就抛异常了。java Heap中有三个区(三代),Young(年轻代),Tenured(老年代),Perm(持久代),Perm就是用于存放静态文件(如应用中动态生成的类),JVM在默认情况下为Perm分配的存储空间是64M,很多程序需要大量的Perm区内存,特别是Spring框架(动态生成的类太多),所以就导致java.lang.OutOfMemoryError:PermGen Space异常的发生。解决方法:,增大JVM的 -XX:MaxPermSize 启动参数,默认是64M,改成128M,或者更大,tomcat的修改如下:TOMCAT_HOME/bin/catalina.bat(windows版本):找到这行echo Using CATALINA_BASE:   "%CATALINA_BASE%",在其前面加入这句,set JAVA_OPTS=%JAVA_OPTS% -server -XX:PermSize=128M -XX:MaxPermSize=512m;catalina.sh(linux版本):JAVA_OPTS="$JAVA_OPTS -server -XX:PermSize=128M -XX:MaxPermSize=512m"。

java.lang.OutOfMemoryError:Heap Space的异常,我在查询大量数据的时候经常遇到,网上说在JVM中如果98%的时间是用于GC且可用的 Heap size不足2%的时候将抛出此异常信息。Heap就是上面提到的Young和Tenured,默认的也是64M,tomcat修改同上,假如这句:set JAVA_OPTS=%JAVA_OPTS% -server -Xms800m -Xmx800m -XX:MaxNewSize=256m(windows),JAVA_OPTS="$JAVA_OPTS -server -Xms800m -Xmx800m -XX:MaxNewSize=256m"(linux)。
以上这些是在tomcat中设置的,如果是在windows环境下,也可以通过环境变量来设置。

你可能感兴趣的:(java,spring,jvm,tomcat,linux)