亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

JRockit檢測Tomcat內存溢出JAVA內存泄漏問題

系統 1784 0
? 公司的一個JAVA應用系統上線以來,基本每1天OutOfMemoryError: PermGen space一次。JAVA堆上限1個G,出現了好多次,想到JRockit可以分析內存泄漏的問題:
1. JRockit簡介
Jrockit是Bea開發的符合JAVA虛擬機規范的虛擬機+虛擬機監控軟件。
虛擬機:Jrockit Real Time
監控軟件:Jrockit Mission Control
Jrockit Real Time與SUN的JDK是完全兼容的,也就是說以前在SUN的虛擬機上跑的程序,在Jrockit Real Time上不會出現任何問題。
以前這套軟件只提供1個小時的免費監控時間。就是說虛擬機啟動1個小時內監控軟件可以連上,過了一個小時就連不上了。這對一天才泄漏20M的應用程序來說,沒有什么意義。現在已經完全免費了。這是開發者的福音。
最重要的,Jrockit是目前作者嘗試過的,唯一一套可以在生產環境中進行內存監控的軟件,其他軟件都會嚴重降低虛擬機的效率應用基本無法使用。因為內存泄漏有時就算在壓力測試中也很難發現。大部分都是在生產環境中產生的。如果沒有一個基本不影響運行效率的軟件,想解決只能靠運氣。以前我解決過一次JAVA內存泄漏的問題,將程序從WEBLOGIC遷移到TOMCAT上解決了決完全屬于運氣。現在有了這個工具,解決起來就非常方便了。

2. 下載JRockit3.1.0,并安裝
下載地址: http://www.oracle.com/technology/software/products/jrockit/index.html
要同時下載Jrockit Mission Control 3.1.0(監控軟件)和Jrockit Real Time 3.1.0(虛擬機)


3. 服務器端配置
1. 在服務器段安裝Jrockit Real Time 3.1.0,
2. 設置應用程序,使用此Jrockit啟動應用程序。
Tomcat 6的設置方法是:
在catalina.sh頂部加入
JAVA_OPTS=" -verbosegc -Dcom.sun.management.jmxremote.port=7091 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -Djava.rmi.server.hostname=本機IP "和
JRE_HOME="Jrockit虛擬機路徑"
將JRE_HOME改為JAVA_HOME也行。
3. 下載 http://download2.bea.com/pub/license/All%20Products/BEA_WebLogic.zip ,解壓后將其中的LIC-WLRT20.txt文件改名為license.bea上傳到%JROCKIT_HOME%/jre/下。
4. 監控端設置
首先安裝Jrockit Mission Control 3.1.0,然后運行之。
在JVM瀏覽器視圖中,對連接器文件夾右鍵,選擇新建連接。彈出下圖:



在“主機”處輸入IP,服務器開放的端口已經是7091,所以不必修改。其他的不用動。點擊“測試連接”狀態如果是確定則代表已經連接。點擊Finish保存新建的連接。在“連接器”文件夾新建了一個連接。
5. 開始監控內存
在新建的連接器上點擊右鍵,選擇“啟動Memleak”,如圖:


彈出內存泄露檢測器,如圖:



最先看見的是“趨勢”選項卡,里邊標注了占用JAVA堆大于0.1%的類和數組。
“類型”選項卡,顯示了類型與類型之間的引用情況。
“實例”選項卡,顯示了實例之間的引用情況。
“分配堆棧跟蹤”選項卡,顯示了指定類型在虛擬機運行過程中被使用的情況。
6. 實戰
公司的一個JAVA應用系統上線以來,基本每1天OutOfMemory一次。JAVA堆上限1個G。
6.1 10點45分內存使用情況抓屏(趨勢選項卡)
注:抓屏前都進行了完全的垃圾回收。



6.2 13點17分內存使用情況抓屏




6.3 結論
占用內存最高的類為:
edu.emory.mathcs.java.util.concurrent.ConcurrentHashMap$Segment
此類從10點多的95M漲到13點的129M。沒有釋放內存。此類引起內存泄露。
edu.emory.mathcs屬于backport-util-concurrent開源項目。用于線程并發編程。屬于java.util.concurrent包的另一個實現。
7. 堆棧分配跟蹤
知道是那個類出了問題,然后就需要知道系統中都那些類使用了這個問題。在edu.emory.mathcs.java.util.concurrent.ConcurrentHashMap$Segment上右鍵,選擇“顯示分配跟蹤”,進入“分配堆棧跟蹤”選項卡,
跟蹤一段時間如圖:



此時就會發現,使用backport-util-concurrent的是AXIS2,使用AXIS2的是我們項目里的文件,并且里邊已經標注了堆棧(包名.類名.方法名(文件名:行數) ),這樣就知道那里出現問題,對癥下藥就能夠解決了。去修改代碼吧。HOHO~


來源: Heck's Blog
地址: http://www.hecks.tk/JRockit-testing-OutOfMemoryError-PermGen-space/

JRockit檢測Tomcat內存溢出JAVA內存泄漏問題


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 一区二区三区久久 | 国产精品久久久久久久久久一区 | 夜夜橹 | 国产精品久久国产精麻豆99网站 | 国产精品久久久久免费视频 | 操天天操 | 亚洲乱视频 | 久久99爱视频 | 精品欧美在线 | 精彩视频一区二区三区 | 精品成人一区二区三区免费视频 | 久久国产精品二国产精品 | 深夜影院在线视频观看 | 尤物精品国产福利网站 | 老司机午夜精品视频在线观看免费 | 国产九九精品 | 亚洲综合爱爱久久网 | 亚洲狠狠婷婷综合久久久图片 | 亚洲七七久久精品中文国产 | 天天上天天干 | 亚洲欧美日韩国产精品久久 | 老司机免费福利视频无毒午夜 | 色综合一区 | 久久综合九色综合狠狠97 | 激情五月综合综合久久69 | 伊人久久大香线蕉亚洲 | 亚洲视频在线a视频 | 精品福利在线 | 欧美色成人tv在线播放 | 亚洲综合专区 | 中国一级毛片aaa片 中国一级毛片录像 | 四虎在线观看免费视频 | 激情五月综合婷婷 | 久久精品视频免费播放 | 国产视频久久久 | 91麻豆精品国产91久久久久 | 国产黄片毛片 | 五月天婷婷网址 | 久久夜色精品国产噜噜小说 | 99爱国产 | 爽爽影院免费观看视频 |