新聞中心
公司有個JSP項目內(nèi)存經(jīng)常溢出,tomcat兩個小時左右就停,我寫了一個類對JVM可用內(nèi)存進行了監(jiān)測

專注于為中小企業(yè)提供網(wǎng)站建設、網(wǎng)站制作服務,電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)山西免費做網(wǎng)站提供優(yōu)質(zhì)的服務。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了1000多家企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
- 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;
- }
- }
這個類雖然簡單,但初學者從中應該學到
1)timer類的用法
2)java.lang.Runtime.getRuntime().freeMemory(),java.lang.Runtime.getRuntime().totalMemory(),System.gc()
這三個方法的使用,需要說明的是System.gc()并不能強迫JVM馬上釋放內(nèi)存,如果那樣,我的內(nèi)存溢出問題早就解決了.
3)getInstance()單例模式,
4)***的就是怎么用這個類的問題,我把它放到了EncodingFilter類中,現(xiàn)在很多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;
- }
- }
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溢出時在window資源管理器中tomcat內(nèi)存占300多M,MSSQL內(nèi)存也差不多到300M了.有什么辦法可以定時重啟這兩個服務呢,我寫了一個程序,在XP下可用.但2000下不能用.
網(wǎng)頁名稱:監(jiān)視JSP中JVM可用內(nèi)存
本文網(wǎng)址:http://m.5511xx.com/article/dpiipoo.html


咨詢
建站咨詢
