this is a extra element for clear the floated element
JSP中监测JVM的内存使用情况
  • 12/31
  • 2008
Servlet/JSP | Java 1722 次查看
  packagecn.zhuangyan.util;

  importjava.util.Timer;

  importjava.util.TimerTask;

  importjava.util.Calendar;

  importjava.util.GregorianCalendar;

  /**

  *

  *<p>Title:GCTimerTask</p>

  *

  *@authorzhuangyan

  *@msn:nacl_zhuang@hotmail.com

  *@qq:368924454

  *@version1.0

  */

  publicclassGCTimerTask

  extendsTimerTask{

  privatestaticGCTimerTaskinstance=null;

  publicvoidrun(){

  Calendarcal=newGregorianCalendar();

  inthour24=cal.get(Calendar.HOUR_OF_DAY);//0..23

  intmin=cal.get(Calendar.MINUTE);//0..59

  System.out.print("["+String.valueOf(hour24)+":"+String.valueOf(min)+"]");

  System.out.println("JVM可用内存:"+java.lang.Runtime.getRuntime().freeMemory()/(1024*1024)+"M/"+java.lang.Runtime.getRuntime().totalMemory()/(1024*1024)+"M");

  System.gc();

  }

  privatevoidstartWork()

  {

  Timert=newTimer();

  t.schedule(instance,0,1000*60);

  }

  publicstaticGCTimerTaskgetInstance()

  {

  if(instance==null)

  {

  instance=newGCTimerTask();

  instance.startWork();

  }

  returninstance;

  }

  }

  这个类虽然简单,但初学者从中应该学到

  1)timer类的用法

  2)java.lang.Runtime.getRuntime().freeMemory(),java.lang.Runtime.getRuntime().totalMemory(),System.gc()

  这三个方法的使用,需要说明的是System.gc()并不能强迫JVM马上释放内存,如果那样,我的内存溢出问题早就解决了.

  3)getInstance()单例模式,

  4)最后的就是怎么用这个类的问题,我把它放到了EncodingFilter类中,现在很多jsp程序中都有这个类吧,

  publicfinalvoidinit(finalFilterConfigarg0)throwsServletException{

  GCTimerTask.getInstance();

  this.filterConfig=arg0;

  this.encoding=filterConfig.getInitParameter("encoding");

  Stringvalue=filterConfig.getInitParameter("ignore");

  if(value==null){

  this.ignore=true;

  }elseif(value.equalsIgnoreCase("true")){

  this.ignore=true;

  }elseif(value.equalsIgnoreCase("yes")){

  this.ignore=true;

  }else{

  this.ignore=false;

  }

  }

  =====================================

  下面是溢出时日志,高手帮看一下.

  [9:42]JVM可用内存:405M/508M

  java.lang.OutOfMemoryError

  [9:43]JVM可用内存:405M/508M

  [9:44]JVM可用内存:405M/508M

  [9:45]JVM可用内存:405M/508M

  [9:46]JVM可用内存:405M/508M

  [9:47]JVM可用内存:405M/508M

  [9:48]JVM可用内存:404M/508M

  [9:49]JVM可用内存:405M/508M

  [9:50]JVM可用内存:404M/508M

  [9:51]JVM可用内存:405M/508M

  [9:52]JVM可用内存:405M/508M

  [9:53]JVM可用内存:404M/508M

  [9:54]JVM可用内存:405M/508M

  [9:55]JVM可用内存:404M/508M

  [9:56]JVM可用内存:405M/508M

  [9:57]JVM可用内存:405M/508M

  [9:58]JVM可用内存:405M/508M

  [9:59]JVM可用内存:405M/508M

  [10:0]JVM可用内存:405M/508M

  [10:1]JVM可用内存:399M/508M

  [10:2]JVM可用内存:404M/508M

  [10:3]JVM可用内存:404M/508M

  [10:4]JVM可用内存:404M/508M

  [10:5]JVM可用内存:405M/508M

  java.lang.OutOfMemoryError

  为什么显示的可用内存有400多M,还OutOfMemoryError?在window的资源管理器中看tomcat的内存用量是持续增加的,它和java.lang.Runtime.getRuntime().freeMemory()是什么区别啊?

  溢出时在window资源管理器中tomcat内存占300多M,MSSQL内存也差不多到300M了.有什么办法可以定时重启这两个服务呢,我写了一个程序,在XP下可用.但2000下不能用.