隨筆-124  評論-49  文章-56  trackbacks-0
          最近一直被內存溢出捆擾,現在對這幾天的工作做個小小的總結!另外給首次與到此類問題的小鳥們作個提示,希望大家早日變成老鳥!

          1 首先確認是不是內存溢出,如果直接報OutOfMemoryException,那肯定是內存溢出,有時可能沒有發現這個錯誤,但WEB服務到最后還是掛了,也有可能是由Memory Out,如何確認,最好的辦法就是查看gc日志。

          2 如果確認是內存溢出,不要急著跟蹤,因為要找到確切位置還是有一定困難的,個人建議對最近修改的代碼作一次全面檢查,對于有可能出現內存溢出的地方作些修改。
          可能出現的原因:
          (1) 遞歸、循環,這里要注意隱性的地筆,如攔載器,我自已遇到一次攔載器的死循環
          (2) static 的對象,查看static里面是不是有大量的對象塞進去
          (3)Set/List/Map對象,查看Set/List/Map里面是不是有對象用完了沒有釋放
          (4)session/application,查看session里的對象、過期時間等,看是不是無法即時釋放
          (5)ClassLoader,Java ClassLoader結構的使用為內存泄漏提供了許多可乘之機。這個我不知道深層原因,有知道的可以告訴我,將不勝感謝!
          (6)String,字符串累加也容易出現溢出。一般順序StringBuilder,StringBuffer,String。
          (7)全局變量,盡量不使用,使用了即時釋放
          修改后再查看日志,也許問題已經解決了。

          3 如果還是有溢出就只能上工具了,我使用的是JProfiler,功能很強大,首先我在window上遠程監控linux,結果失敗,原因是因為JProfiler本身就有很大的消耗,而且在測試中還要不斷gc,影響生產,所以選用在測試環境中配合jmeter測試。

          4 測試方法:循環測試,查看gc后是否有對象數量不斷增加,即有對象未釋放。

          5 其此是要了解java內存分配原理和gc的工作原理,這樣才可以定位到問題的具體位置。

          6 對jvm進行優化。




          具體操作未詳細說明,可以參考相關資料

          java內存泄漏原因 http://www.ibm.com/developerworks/cn/java/l-JavaMemoryLeak/

          gc原理http://chenchendefeng.javaeye.com/blog/455883

          jvm優化http://www.cjsdn.net/post/view?bid=1&id=197954

          JVM調優-解決native heap持續增長 http://sw1982.javaeye.com/blog/724626 薦



          posted on 2010-07-22 11:11 junly 閱讀(2195) 評論(1)  編輯  收藏 所屬分類: java

          評論:
          # re: 內存溢出跟蹤筆錄 2010-07-22 17:34 | jack_yin
          <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
          <HTML>
          <style type="text/css">
          .button{
          height:19px;background-color: #f1f1f1;margin:none;padding:0 2px 0 3px!important;padding: 0 1px 0 2px;color: #000000;border-top: 1px solid #CCCCCC;border-left: 1px solid #CCCCCC;border-right: 1px solid #CCCCCC;border-bottom:1px solid #CCCCCC;background-image: url(img/button_bg.gif);margin:0 0 0 0;}
          </style>
          <BODY>
          <input type="button" value="計時開始" class="button" id="buttonTime" onclick="startTime();" />
          <input type="text" id="displayTime" readonly="readonly" align="middle" />
          <input type="button" value="統計" class="button" onclick="getResult();" />
          <input type="text" id="displayMoney" />
          <input type="button" onclick="toZero();" value="歸零" class="button" />
          <br />
          <input type="image" src="hide_b.gif" style=" background:#999999" />

          <SCRIPT language=javascript>
          <!--
          //document.write("");

          var currentTime;
          var stopTimeout;
          function show_date_time(){

          stopTimeout = window.setTimeout("show_date_time()",1/1000);
          timeold=((new Date()).getTime()-currentTime.getTime());
          sectimeold=timeold/1000 ;
          secondsold=Math.floor(sectimeold);
          msPerDay=24*60*60*1000 ;
          e_daysold=timeold/msPerDay;
          daysold=Math.floor(e_daysold);
          e_hrsold=(e_daysold-daysold)*24;
          hrsold=Math.floor(e_hrsold);
          e_minsold=(e_hrsold-hrsold)*60;
          minsold=Math.floor((e_hrsold-hrsold)*60);
          seconds=Math.floor((e_minsold-minsold)*60);
          document.getElementById("displayTime").value=""+daysold+"天"+hrsold+"小時"+minsold+"分"+seconds+"秒";

          }

          function startTime(){
          var v = document.getElementById("buttonTime").value;
          currentTime=new Date();
          if(v=="計時開始"){
          document.getElementById("buttonTime").value="停止計時";
          show_date_time();
          }
          else{
          document.getElementById("buttonTime").value="計時開始";
          window.clearTimeout(stopTimeout);
          }
          }

          function getResult(){
          document.getElementById("buttonTime").value="計時開始";
          document.getElementById("displayMoney").value="one dollar";
          window.clearTimeout(stopTimeout);
          }

          function toZero(){
          document.getElementById("displayTime").value="0天0小時0分0秒";
          document.getElementById("displayMoney").value="";
          }
          //-->
          </SCRIPT>
          </BODY>

            回復  更多評論
            
          主站蜘蛛池模板: 渝中区| 南汇区| 洛川县| 车致| 同心县| 壤塘县| 石楼县| 邵阳县| 宣威市| 鄂托克旗| 临泉县| 嘉善县| 江源县| 延吉市| 乌拉特中旗| 滨州市| 遂溪县| 东乡县| 开原市| 西贡区| 洛川县| 安溪县| 木里| 海晏县| 衡南县| 乌拉特后旗| 金山区| 南宁市| 丰原市| 永安市| 旺苍县| 乐昌市| 杂多县| 宜兰县| 瑞金市| 缙云县| 永新县| 温州市| 偃师市| 慈溪市| 永康市|