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

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

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

    posts - 28,  comments - 15,  trackbacks - 0

     

    系統(tǒng)有時會遇到OutOfMemoryError,Java堆溢出了。我們需要找到造成OutOfMemoryError原因。一般有兩種情況:

    1、內(nèi)存泄露,對象已經(jīng)死了,無法通過垃圾收集器進行自動回收;

    2、內(nèi)存溢出,內(nèi)存中的對象都還必須存活著,這說明Java堆分配空間不足,檢查堆設(shè)置大小(-Xmx與-Xms),檢查代碼是否存在對象生命周期太長、持有狀態(tài)時間過長的情況。


    想在泄漏未發(fā)生前,取堆轉(zhuǎn)儲文件分析, 通過jvm參數(shù)-XX:+HeapDumpOnOutOfMemoryError(XX:+HeapDumpOnCtrlBreak不知道為什么tomcat啟動不了)可以讓JVM在出現(xiàn)內(nèi)存溢出是Dump出當(dāng)前的內(nèi)存轉(zhuǎn)儲快照。

    當(dāng)然也可以通過用jmap生產(chǎn)dump文件。windows通過任務(wù)管理器查看tomcat的進程pid,linux用ps命令查看進程pid,然后用jmap命令(Java5:jmap -heap:format=b <pid>;Java6:jmap -dump:format=b,file=HeapDump.bin <pid>)

     

    在tomcat中設(shè)置jvm參數(shù)

    linux系統(tǒng)中

    1.打開/tomcat_home/bin/catalina.sh文件 

    2.加上:JAVA_OPTS="$JAVA_OPTS -server -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump"

    如下圖位置:

    注:其中不設(shè)-XX:HeapDumpPath時,dump出的文件在/tomcat_home/bin目錄下

    Windows系統(tǒng)中

    1.打開/tomcat_home/bin/catalina.bat文件

    2.加上:set JAVA_OPTS=%JAVA_OPTS% -server -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=D:\heapdump

    如下圖位置:

     

    分析dump出來的內(nèi)存快照文件


    可以使用分析工具進行分析,如:

     

    Eclipse的MAT

    下載地址:http://www.eclipse.org/mat/downloads.php

    說明文檔:http://www.vogella.com/articles/EclipseMemoryAnalyser/article.html#example_project

     

    注意:解析過大的HeapDump可能導(dǎo)致Eclipse拋出OutOfMemory的錯誤。這時你需要手動調(diào)整Eclipse的緩存大小,可以參考官網(wǎng)給出的處理方式(原文連接

     

    Alternatively, edit the MemoryAnalyzer.ini to contain:

    -vmargs
    -Xmx2g
    -XX:-UseGCOverheadLimit

    Eclipse插件版打不開的朋友可以試試 RPC版的MAT (我的232m的dump文件也打不開,難道非得用64bit的機器嗎?):RPC版MAT下載地址

     

    JProfile

     

    等等;

    轉(zhuǎn)自:http://jiangsha.iteye.com/blog/1576355

    posted on 2013-03-18 16:53 zhangxl 閱讀(20325) 評論(2)  編輯  收藏 所屬分類: 優(yōu)化


    FeedBack:
    # re: tomcat 產(chǎn)生heapdump文件配置
    2014-01-23 15:19 | tyler
    我分析heapdump用的機器是16G內(nèi)存的。有一次還不得不打開磁盤交換。分析heapdump比產(chǎn)生heapdump消耗的內(nèi)存更多。  回復(fù)  更多評論
      
    # re: tomcat 產(chǎn)生heapdump文件配置
    2016-01-18 22:29 | 小龍在線
    如果不內(nèi)存溢出,heapdump目錄是不是空的?  回復(fù)  更多評論
      

    只有注冊用戶登錄后才能發(fā)表評論。


    網(wǎng)站導(dǎo)航:
    博客園   IT新聞   Chat2DB   C++博客   博問  
     
    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(1)

    隨筆分類(17)

    隨筆檔案(28)

    文章分類(30)

    文章檔案(30)

    相冊

    收藏夾(2)

    hibernate

    java基礎(chǔ)

    mysql

    xml

    關(guān)注

    壓力測試

    算法

    最新隨筆

    搜索

    •  

    積分與排名

    • 積分 - 96306
    • 排名 - 601

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 国产精品视频白浆免费视频| 成年人免费视频观看| 亚洲成a人片毛片在线| 亚洲综合中文字幕无线码| 黄a大片av永久免费| APP在线免费观看视频| 亚洲精品国产精品乱码在线观看| 亚洲Av永久无码精品一区二区| 国产成人高清亚洲| 51精品视频免费国产专区| 最新亚洲人成网站在线观看| 国产片免费福利片永久| 久久精品国产亚洲av品善| 国产亚洲人成网站在线观看不卡| 午夜福利不卡片在线播放免费| 免费精品国自产拍在线播放| 亚洲视频一区网站| 亚洲片国产一区一级在线观看| 91免费国产自产地址入| www免费插插视频| 亚洲AV无码无限在线观看不卡 | **实干一级毛片aa免费| 亚洲AV永久无码精品放毛片| 亚洲综合激情另类小说区| 免费大片黄在线观看yw| free哆拍拍免费永久视频| 亚洲欧美成人一区二区三区| 亚洲AV无码欧洲AV无码网站| 免费看国产曰批40分钟| 最近中文字幕高清免费中文字幕mv| 一级免费黄色毛片| 亚洲欧美成人一区二区三区| 亚洲欧洲精品久久| 亚洲精品乱码久久久久久久久久久久| 最近最新中文字幕完整版免费高清| 免费毛片a线观看| 久久99久久成人免费播放| 精品在线观看免费| 亚洲熟妇AV日韩熟妇在线| 亚洲国产日韩女人aaaaaa毛片在线 | 四虎影视无码永久免费|