| |
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下不能用.
|
|