网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>JAVA>>新手入门>>基础入门>查看文档  
  jsp中监测jvm的内存使用情况     
  文章作者:未知  文章来源:水木森林  
  查看:140次  录入:管理员--2007-11-17  
 
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下不能用.
 
 
上一篇: java学习 - 乱评prototype.js    下一篇: jsp学习记录(三)——jsp表达式
  相关文档
关于java编程的中文问题的几条分析原则 11-16
java中有关日期的显示问题 11-16
java动画编程基础 11-17
java布局管理器使用方法探讨 11-16
win2000下apache2与tomcat5的整合配置 11-16
新手入门:java 程序设计之“对象”篇 11-16
使用php程序直接调用文本文件的内容实例 06-30
java对internet为什么重要 11-17
java 实现连接sql server 2000(jdbc数据库访问例子) 11-17
java开发为什么需要uml? 11-16
全面解析jdbc(1) 11-17
java 技术在嵌入式系统中的应用详解 11-17
用j2se1.5建立多任务的java应用程序 11-16
浅析数学能力对于编程工作者有很大影响 11-16
再谈客户端的java技术 11-17
getfileversion 方法 11-16
用java实现http文件队列下载 11-16
体验java 1.5中面向(aop)编程 11-16
java中设计模式(2)singleton模式 11-17
轻松搞定java内存泄漏 11-17
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
厦门(总部):13616026886 福州:0591-87655121
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息