監(jiān)視JSP中JVM可用內(nèi)存
公司有個(gè)JSP項(xiàng)目?jī)?nèi)存經(jīng)常溢出,tomcat兩個(gè)小時(shí)左右就停,我寫了一個(gè)類對(duì)JVM可用內(nèi)存進(jìn)行了監(jiān)測(cè)
- import java.util.Timer;
- import java.util.TimerTask;
- import java.util.Calendar;
- import java.util.GregorianCalendar;
- /**
- Title:GCTimerTask
- * @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可用內(nèi)存:" + 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;
- }
- }
這個(gè)類雖然簡(jiǎn)單,但初學(xué)者從中應(yīng)該學(xué)到
1)timer類的用法
2)java.lang.Runtime.getRuntime().freeMemory(),java.lang.Runtime.getRuntime().totalMemory(),System.gc()
這三個(gè)方法的使用,需要說明的是System.gc()并不能強(qiáng)迫JVM馬上釋放內(nèi)存,如果那樣,我的內(nèi)存溢出問題早就解決了.
3)getInstance()單例模式,
4)***的就是怎么用這個(gè)類的問題,我把它放到了EncodingFilter類中,現(xiàn)在很多JSP程序中都有這個(gè)類吧
- 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;
- }
- }
JVM可用內(nèi)存:405M/508M
java.lang.OutOfMemoryError
為什么顯示的JVM可用內(nèi)存有400多M,還OutOfMemoryError?在window的資源管理器中看tomcat的內(nèi)存用量是持續(xù)增加的,它和 java.lang.Runtime.getRuntime().freeMemory()是什么區(qū)別啊?
JSP溢出時(shí)在window資源管理器中tomcat內(nèi)存占300多M,MSSQL內(nèi)存也差不多到300M了.有什么辦法可以定時(shí)重啟這兩個(gè)服務(wù)呢,我寫了一個(gè)程序,在XP下可用.但2000下不能用.
【編輯推薦】