阅读这边文章之前,确保您已经看过这篇文章所讲的关于内存溢出的原理:【Java内存溢出 】
从这篇文章中我们了解到一些基础理论:
1、如果JVM在80%的时间都用于GC并且可用的HeapSize不足2%时就会导致产生OutOfMemoryError;
2、HeapSize最大不要超过物理内存的80%,一般设置-xms和-xmx相同,-xmn为-xmx的1/4;
3、JVM初始分配的内存由-xms决定,默认为物理内存的1/64,-xmx默认为物理内存的1/4,如果空余堆内存小于40%时,JVM就会增大堆直到-xmx指定的大小限制,如果空余堆内存大于70%时,JVM就会减小堆知道-xms指定的大小,因此服务器一般设置-xms和-xmx相同,避免每次GC后调整堆大小。
从上面的理论我们看到,在程序编写中我们应该尽量减小全局变量的使用、避免在循环中创建大对象、避免在同一时刻创建大量对象、对于不再使用的对象,我们应该显示设置其应用为空等等。
当然,除过上面的程序代码优化外,正确的设置也是提升系统性能,排除内存溢出的重要途径。
1、设置JVM的HeapSize:
java -xms256m -xmx256 MyJavaApplication
在具体的WEB服务器中设置略有不同。
2、设置Tomcat的JVM内存大小:
修改catalina.bat,在开头部分加入:
set JAVA_OPTS=-Xms256m -Xmx256m
3、设置Derby数据库使用JVM内存大小:
修改ij.bat的部分,添加JVM内存设置参数:
:runNoClasspath
"%_JAVACMD%" %DERBY_OPTS% -Xms128m -Xmx128m -classpath "%LOCALCLASSPATH%" org.apache.derby.tools.ij %DERBY_ARGS% %DERBY_CMD_LINE_ARGS%
goto end
:runWithClasspath
"%_JAVACMD%" %DERBY_OPTS% -Xms128m -Xmx128m -classpath "%CLASSPATH%;%LOCALCLASSPATH%" org.apache.derby.tools.ij %DERBY_ARGS% %DERBY_CMD_LINE_ARGS%
注意:在Derby应用中通过设置Derby数据库的页大小,也可以提升性能。
1、设置页大小:
CALL SYSCS_UTIL.SYSCS_SET_DATABASE_PROPERTY( 'derby.storage.pageSize' , '16384');
2、查看页大小:
values SYSCS_UTIL.SYSCS_GET_DATABASE_PROPERTY('derby.storage.pageSize' );
可以参考【Derby的官方文档 】