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

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

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

    笨笨的思想片斷

    零碎片斷,雜七雜八。
    posts - 25, comments - 79, trackbacks - 0, articles - 0

    Java 多線程或內(nèi)存泄漏缺陷排查的一些經(jīng)驗


    JVM Thread DUMP 基本功
    Windows 下用Ctrl-Break,Unix 下用 kill -3 <pid> 的命令讓JVM輸出 thread dump。
    每隔幾秒 thread dump 一次,多做幾次,分析比較。

    Thread Dump分析的一些經(jīng)驗
    1 找出這幾次Thread dump 文件中,有哪些 Java Thread 處于長時間等待狀態(tài),很有可能就是問題之所在。
    2 如果Java 線程等在某些不可能出錯的地方,如 java.lang.XXX/java.util.XXX對象的某個方法,則很有可能是因為出現(xiàn)了 OutOfMemoryError 異常,原因不外乎是JVM 堆內(nèi)存過小或出現(xiàn)內(nèi)存泄漏。
    3 對于死鎖,最直接的表現(xiàn)就是至少兩個線程長時間等待相互持有的對象(每個線程所持有的對象和它當(dāng)前等待的對象都可以從 dump 中看到)。
    4 對于死循環(huán),要輔助CPU占用率確定;如果發(fā)現(xiàn)CPU至少一顆使用率為100%,并且有線程長時間位于用戶代碼處,則很有可能是死循環(huán)引起。


    多線程缺陷排查
    對于Java死鎖問題很少出現(xiàn),多線程訪問變量時沖突很常見。
    一般出在多線程共享同一對象實例如全局Map,Servlet,Interceptor,或如多線程同時訪問某個靜態(tài)方法,而此靜態(tài)方法不巧又訪問另一個靜態(tài)變量。
    這類問題自測發(fā)現(xiàn)不了,在并發(fā)壓力測試時才能發(fā)現(xiàn)。如果代碼的入口檢查做得好,多半會拋出一些莫名其妙的異常;要不然就會出現(xiàn)正常運行但數(shù)據(jù)庫記錄不對的情況。
    對這種問題,并無多好的辦法解決,主要還是靠看異常堆棧和靜態(tài)代碼分析來解決。


    內(nèi)存泄漏排查
    一般用商用輔助工具排查,但有可能出現(xiàn)在JVM heap dump 模式下,運行極度緩慢的情況。
    笨笨曾經(jīng)用過一個非常簡單的工具,效果不錯,它可以做到在不影響jvm 執(zhí)行速度的情況下,做heap dump,然后對dump出的文件進行排序,檢查即可。

    heapprofile(http://www.virtualmachine.de/)

     

    Feedback

    # 如何能讓thread dump的結(jié)果輸出在文件中?  回復(fù)  更多評論   

    2007-05-16 17:42 by ldz
    thread dump的結(jié)果太長了,
    如何能讓thread dump的結(jié)果輸出在文件中?

    # re: Java 多線程或內(nèi)存泄漏缺陷排查的一些經(jīng)驗  回復(fù)  更多評論   

    2007-05-16 19:46 by 笨笨
    要分 JDK .
    IBM JDK 始終輸出 Thread Dump到某個文件中。
    Sun/Jrockit JDK 會輸出到 stdout 中。

    對于 Sun/JRockit JDK,最簡單的辦法 是重定向 stdout 到某個文件: java xxxx > xxx.out

    最復(fù)雜的辦法是用 JNI 實時修改 STDOUT/STDERR handler。
    主站蜘蛛池模板: 男人和女人高潮免费网站| 亚洲一区二区久久| 一级做性色a爰片久久毛片免费| 成熟女人牲交片免费观看视频| 亚洲三级在线观看| 女人被弄到高潮的免费视频| 亚洲色丰满少妇高潮18p| 日韩免费视频播放| 黄色毛片免费观看| 亚洲欧洲日本在线| 国产亚洲免费的视频看| 婷婷久久久亚洲欧洲日产国码AV| 国产va在线观看免费| 亚洲福利一区二区| 国产精品美女自在线观看免费| 国产精品亚洲色婷婷99久久精品| 亚洲Av无码国产情品久久| 中文字幕免费在线看| 亚洲激情视频在线观看| 韩国免费一级成人毛片| 亚洲第一se情网站| 久久精品国产亚洲AV麻豆不卡| 又黄又爽又成人免费视频| 亚洲乱码中文字幕在线| 精品国产人成亚洲区| 91短视频在线免费观看| 亚洲熟伦熟女专区hd高清| 国产亚洲一区区二区在线| 91精品视频在线免费观看| 亚洲jizzjizz少妇| 亚洲日本一区二区三区在线| 99久久免费国产香蕉麻豆| 精品在线视频免费| 亚洲精品一卡2卡3卡三卡四卡| 最好免费观看韩国+日本| 在线观看免费黄色网址| 亚洲中文字幕无码中文| 亚洲精品成人片在线观看精品字幕| 91九色视频无限观看免费| 国产精品亚洲а∨天堂2021| 亚洲av日韩av高潮潮喷无码|