<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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

    1 首先確認(rèn)是不是內(nèi)存溢出,如果直接報(bào)OutOfMemoryException,那肯定是內(nèi)存溢出,有時(shí)可能沒有發(fā)現(xiàn)這個錯誤,但WEB服務(wù)到最后還是掛了,也有可能是由Memory Out,如何確認(rèn),最好的辦法就是查看gc日志。

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

    3 如果還是有溢出就只能上工具了,我使用的是JProfiler,功能很強(qiáng)大,首先我在window上遠(yuǎn)程監(jiān)控linux,結(jié)果失敗,原因是因?yàn)镴Profiler本身就有很大的消耗,而且在測試中還要不斷gc,影響生產(chǎn),所以選用在測試環(huán)境中配合jmeter測試。

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

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

    6 對jvm進(jìn)行優(yōu)化。




    具體操作未詳細(xì)說明,可以參考相關(guān)資料

    java內(nèi)存泄漏原因 http://www.ibm.com/developerworks/cn/java/l-JavaMemoryLeak/

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

    jvm優(yōu)化http://www.cjsdn.net/post/view?bid=1&id=197954

    JVM調(diào)優(yōu)-解決native heap持續(xù)增長 http://sw1982.javaeye.com/blog/724626 薦



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

    評論:
    # re: 內(nèi)存溢出跟蹤筆錄 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="計(jì)時(shí)開始" class="button" id="buttonTime" onclick="startTime();" />
    <input type="text" id="displayTime" readonly="readonly" align="middle" />
    <input type="button" value="統(tǒng)計(jì)" 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+"小時(shí)"+minsold+"分"+seconds+"秒";

    }

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

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

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

      回復(fù)  更多評論
      
    主站蜘蛛池模板: 毛片免费vip会员在线看| 亚洲精品无码久久一线| 午夜不卡AV免费| 亚洲AV无码成人精品区在线观看| 亚洲网站在线免费观看| 亚洲国产精品日韩av不卡在线| 亚洲日本在线观看视频| 1000部羞羞禁止免费观看视频| 亚洲日韩久久综合中文字幕| 中文字幕亚洲天堂| 国产精品69白浆在线观看免费 | 免费精品视频在线| 亚洲gv白嫩小受在线观看| 免费精品人在线二线三线区别| 国产久爱免费精品视频| 亚洲免费视频网址| 国产成人精品日本亚洲专区61 | a级毛片免费全部播放无码| 亚洲一区二区三区91| 久久亚洲2019中文字幕| 一个人免费观看www视频在线| 99在线视频免费观看| 亚洲人成自拍网站在线观看| 久久久久亚洲AV无码专区首| 国内自产少妇自拍区免费| 先锋影音资源片午夜在线观看视频免费播放 | 亚洲国产高清在线精品一区| 精品亚洲一区二区三区在线观看| 希望影院高清免费观看视频| a级片免费在线播放| 污污的视频在线免费观看| 国产亚洲精品影视在线| 久久亚洲精品国产精品| 亚洲综合久久夜AV | 日韩一区二区免费视频| 2015日韩永久免费视频播放| 99久久免费国产精精品| 一道本在线免费视频| 国产精品亚洲精品日韩动图| 亚洲一区在线免费观看| 7777久久亚洲中文字幕蜜桃|