点击这里给我发消息 点击这里给我发消息

JSP中监测JVM的内存使用情况

添加时间:2013-12-7
    相关阅读: 程序 SQL JSP MSSQL
package cn.zhuangyan.util;

import java.util.Timer;
import java.util.TimerTask;
import java.util.Calendar;
import java.util.GregorianCalendar;
/**
 *
 * <p>Title:GCTimerTask </p>
 *
 * @author zhuangyan
 * @msn:nacl_zhuang@hotmail.com
 * @qq:368924454
 * @version 1.0
 */
public class GCTimerTask
    extends TimerTask {

  private static GCTimerTask instance = null;
  public void run() {
    Calendar cal = new GregorianCalendar();
    int hour24 = cal.get(Calendar.HOUR_OF_DAY); // 0..23
    int min = 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();
  }
  private void startWork()
  {
        Timer t = new Timer();
         t.schedule(instance,0,1000*60);
  }
  public static GCTimerTask getInstance()
  {
        if(instance==null)
        {
                instance = new GCTimerTask();
                instance.startWork();
        }
        return instance;
  }
}


这个类虽然简单,但初学者从中应该学到
1)timer类的用法
2)java.lang.Runtime.getRuntime().freeMemory(),java.lang.Runtime.getRuntime().totalMemory(),System.gc()
这三个方法的使用,需要说明的是System.gc()并不能强迫JVM马上释放内存,如果那样,我的内存溢出问题早就解决了.
3)getInstance()单例模式,
4)最后的就是怎么用这个类的问题,我把它放到了EncodingFilter类中,现在很多jsp程序中都有这个类吧,
public final void init(final FilterConfig arg0) throws ServletException {
      GCTimerTask.getInstance();
        this.filterConfig = arg0;
        this.encoding = filterConfig.getInitParameter("encoding");

        String value = filterConfig.getInitParameter("ignore");
        if (value == null) {

            this.ignore = true;
        } else if (value.equalsIgnoreCase("true")) {

            this.ignore = true;
        } else if (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下不能用.
咨询热线:020-85648757 85648755 85648616 0755-27912581 客服:020-85648756 0755-27912581 业务传真:020-32579052
广州市网景网络科技有限公司 Copyright◎2003-2008 Veelink.com. All Rights Reserved.
广州商务地址:广东省广州市黄埔大道中203号(海景园区)海景花园C栋501室
= 深圳商务地址:深圳市宝源路华丰宝源大厦606
研发中心:广东广州市天河软件园海景园区 粤ICP备05103322号 工商注册