欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JAVACORE與HEAPDUMP生成方法

 更新時(shí)間:2024年08月14日 10:36:11   作者:Z.Virgil  
JavaCore文件主要保存的是Java應(yīng)用各線(xiàn)程在某一時(shí)刻的運(yùn)行的位置,即JVM執(zhí)行到哪一個(gè)類(lèi)、哪一個(gè)方法、哪一個(gè)行上,它是一個(gè)文本文件,打開(kāi)后可以看到每一個(gè)線(xiàn)程的執(zhí)行棧,以stack?trace的顯示,本文介紹JAVACORE與HEAPDUMP生成大法,感興趣的朋友跟隨小編一起看看吧

前言

在項(xiàng)目上我們經(jīng)常要生成javacore和heapdump來(lái)進(jìn)行分析。這里總結(jié)一下我自己在項(xiàng)目上生成這兩個(gè)文件的方法。

JAVACORE篇:

JavaCore文件主要保存的是Java應(yīng)用各線(xiàn)程在某一時(shí)刻的運(yùn)行的位置,即JVM執(zhí)行到哪一個(gè)類(lèi)、哪一個(gè)方法、哪一個(gè)行上。它是一個(gè)文本文件,打開(kāi)后可以看到每一個(gè)線(xiàn)程的執(zhí)行棧,以stack trace的顯示。

通過(guò)對(duì)JavaCore文件的分析可以得到應(yīng)用是否“卡”在某一點(diǎn)上,即在某一點(diǎn)運(yùn)行的時(shí)間太長(zhǎng),例如數(shù)據(jù)庫(kù)查詢(xún),長(zhǎng)期得不到響應(yīng),最終導(dǎo)致系統(tǒng)崩潰等情況。

Windows平臺(tái):

ORACLE JDK:HOTSPOT

1.jvisualvm工具

jvisualvm是sun的JDK中自帶的工具,在java_home/bin/jvisualvm.exe中就可以打開(kāi)。

掛在到對(duì)應(yīng)的java進(jìn)程后,可以直接生javacore。

2.jstack工具

jstack為JDK自帶的命令行工具。

可以通過(guò)jstack -l -r -pid的方式生成對(duì)應(yīng)的javacore。

其中-l -r 可以顯示出詳細(xì)信息,鎖信息等。

3.sendsignal工具

sendsignal工具是老外開(kāi)發(fā)的一個(gè)小工具,用來(lái)生成已知進(jìn)程號(hào)的java進(jìn)程的javacore。

附件中有具體工具。通過(guò)sendsignal.exe pid即可生成。

4.ctrl+break按鍵

在Windows上啟動(dòng)程序的時(shí)候,可以直接在啟動(dòng)進(jìn)程的窗口按組合鍵生成javacore。

然而由于NC涉及到兩個(gè)java進(jìn)程,一個(gè)小的導(dǎo)程序,一個(gè)是正式的程序。

所以用該方法只能生成引導(dǎo)程序的javacore??床坏缴a(chǎn)環(huán)境的實(shí)際快照。

IBM JDK:V9

1.系統(tǒng)宕機(jī)自動(dòng)生成。

IBM的JDK在系統(tǒng)宕機(jī)的時(shí)候會(huì)自動(dòng)生成javacore,這也是我們經(jīng)常用該JDK替換默認(rèn)的緣故。

2.sendsignal工具。

3.ctrl+break組合鍵。

4.NMC控制臺(tái)。(內(nèi)部監(jiān)控工具)

某產(chǎn)品自帶的監(jiān)控工具NMC可以直接點(diǎn)擊對(duì)應(yīng)server,右鍵直接生成javacore。

該工具只針對(duì)于Websphere集群生效。對(duì)于單機(jī) websphere或者NC中間件不生效。

5.Websphere控制臺(tái)。

有的時(shí)候我們發(fā)現(xiàn),系統(tǒng)卡死,或者需要同時(shí)生成多個(gè)Server的javacore的時(shí)候,

我們就需要在websphere的控制臺(tái)中直接生成。

生成方式為T(mén)roubleshooting->Java dumps and cores。

6.JSP小補(bǔ)丁程序。         

使用方式為,將javacore.jsp放置到nchome/webapps/nc_web下即可,重啟生效。

訪(fǎng)問(wèn)的時(shí)候,通過(guò)ip地址+端口+javacore.jsp即可在JAVA_HOME中生成。

如127.0.0.1:9081/javacore.jsp。代碼如下

<%com.ibm.jvm.Dump.JavaDump();%>

主要調(diào)用IBM的JDK內(nèi)部方法com.ibm.jvm.Dump.JavaDump();

LINUX平臺(tái):                  

1.kill -3 -pid

在linux平臺(tái)上,除了之前的各種方法之外,可以直接調(diào)用系統(tǒng)的kill -3方法?!      ?/p>

HEAPDUMP篇:

HeapDump文件是一個(gè)二進(jìn)制文件,它保存了某一時(shí)刻JVM堆中對(duì)象使用情況。

這種文件需要相應(yīng)的工具進(jìn)行分析,如IBM Heap Analyzer這類(lèi)工具。這類(lèi)文件最重要的作用就是分析系統(tǒng)中是否存在內(nèi)存溢出的情況。

Windows平臺(tái):

ORACLE JDK:HOTSPOT

1.jvisualvm工具。

和之前生成javacore的方法類(lèi)似。

2.jmap方法。

map方法為JDK自帶的方法。通過(guò)命令行的方式生成。

<%
com.ibm.jvm.Dump.JavaDump();
%>

3.系統(tǒng)宕機(jī)自動(dòng)生成。

由于oracle的JDK在宕機(jī)的時(shí)候,不會(huì)自動(dòng)生成heapdump文件。需要我們通過(guò)添加JVM參數(shù)的方式來(lái)顯示申明。

在JVM參數(shù)中 加-XX:+HeapDumpOnOutOfMemoryError。

4.通過(guò)windows任務(wù)管理器。

windows的任務(wù)管理器可以直接將java的堆對(duì)象全部轉(zhuǎn)儲(chǔ)出來(lái)。

只需要點(diǎn)擊右鍵進(jìn)行保存即可。保存后的文件需要通過(guò)類(lèi)似IBM的MAT分析工具打開(kāi)。

IBM JDK:V9

1.系統(tǒng)宕機(jī)自動(dòng)生成。

2.利用coredump功能。

利用websphere自帶的coredump功能,可以將所有宕機(jī)時(shí)的堆棧信息全部輸出。

包含堆中對(duì)象的具體信息,如hashmap中的鍵值都可以看到具體的值。

是跟蹤宕機(jī)問(wèn)題的終極法寶。

具體方法為,在JVM中添加參數(shù)
-Xdump:system:events=user,request=exclusive+prewalk+compact

3.JSP小補(bǔ)丁程序。

使用方式為,將heapdump.jsp放置到nchome/webapps/nc_web下即可,重啟生效。

訪(fǎng)問(wèn)的時(shí)候,通過(guò)ip地址+端口+heapdump.jsp即可在JAVA_HOME中生成。

如127.0.0.1:9081/heapdump.jsp。代碼如下

<%
com.ibm.jvm.Dump.HeapDump();
%>

主要調(diào)用IBM的JDK內(nèi)部方法com.ibm.jvm.Dump.HeapDump();

LINUX平臺(tái):

和上面的生成方法沒(méi)有太大區(qū)別。

以上為目前我總結(jié)的所有關(guān)于javacore和heapdump的收集方法。

在搜集項(xiàng)目報(bào)錯(cuò)信息以及定位問(wèn)題的時(shí)候非常關(guān)鍵。

到此這篇關(guān)于JAVACORE與HEAPDUMP生成大法的文章就介紹到這了,更多相關(guān)JAVACORE與HEAPDUMP生成內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java?在游戲中探索數(shù)組二維數(shù)組

    Java?在游戲中探索數(shù)組二維數(shù)組

    數(shù)組和二維數(shù)組感覺(jué)用王者榮耀的裝備欄來(lái)舉例解釋?zhuān)瑧?yīng)該更易懂一些。從基礎(chǔ)開(kāi)始講,后續(xù)會(huì)講到JAVA高級(jí),中間會(huì)穿插面試題和項(xiàng)目實(shí)戰(zhàn),希望能給大家?guī)?lái)幫助
    2022-03-03
  • java理論基礎(chǔ)Stream?reduce實(shí)現(xiàn)集合元素歸約

    java理論基礎(chǔ)Stream?reduce實(shí)現(xiàn)集合元素歸約

    這篇文章主要為大家介紹了java理論基礎(chǔ)Stream?reduce實(shí)現(xiàn)集合元素歸約示例詳解有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步
    2022-03-03
  • Java程序測(cè)試上傳Maven工程代碼示例解析

    Java程序測(cè)試上傳Maven工程代碼示例解析

    這篇文章主要介紹了Java程序測(cè)試上傳Maven工程代碼示例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-08-08
  • Java實(shí)戰(zhàn)之制作在線(xiàn)音樂(lè)網(wǎng)站

    Java實(shí)戰(zhàn)之制作在線(xiàn)音樂(lè)網(wǎng)站

    這篇文章主要介紹了如何通過(guò)Java實(shí)現(xiàn)一個(gè)精美風(fēng)的在線(xiàn)音樂(lè)網(wǎng)站,文章采用到了JSP、JQuery、Ajax等技術(shù),感興趣的小伙伴可以了解一下
    2022-02-02
  • 基于SpringBoot整合SSMP案例(開(kāi)啟日志與分頁(yè)查詢(xún)條件查詢(xún)功能實(shí)現(xiàn))

    基于SpringBoot整合SSMP案例(開(kāi)啟日志與分頁(yè)查詢(xún)條件查詢(xún)功能實(shí)現(xiàn))

    這篇文章主要介紹了基于SpringBoot整合SSMP案例(開(kāi)啟日志與分頁(yè)查詢(xún)條件查詢(xún)功能實(shí)現(xiàn)),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋參考下吧
    2023-11-11
  • MyBatis簡(jiǎn)介與配置MyBatis+Spring+MySql的方法

    MyBatis簡(jiǎn)介與配置MyBatis+Spring+MySql的方法

    MyBatis 是一個(gè)可以自定義SQL、存儲(chǔ)過(guò)程和高級(jí)映射的持久層框架。這篇文章主要介紹了MyBatis簡(jiǎn)介與配置MyBatis+Spring+MySql的方法,需要的朋友可以參考下
    2017-04-04
  • java不用循環(huán)語(yǔ)句打印數(shù)組元素的實(shí)例

    java不用循環(huán)語(yǔ)句打印數(shù)組元素的實(shí)例

    下面小編就為大家?guī)?lái)一篇java不用循環(huán)語(yǔ)句打印數(shù)組元素的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-03-03
  • 修改Maven settings.xml 后配置未生效的解決

    修改Maven settings.xml 后配置未生效的解決

    這篇文章主要介紹了修改Maven settings.xml 后配置未生效的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-10-10
  • SpringBoot整合Mybatis-plus案例及用法實(shí)例

    SpringBoot整合Mybatis-plus案例及用法實(shí)例

    mybatis-plus是一個(gè) Mybatis 的增強(qiáng)工具,在 Mybatis 的基礎(chǔ)上只做增強(qiáng)不做改變,為簡(jiǎn)化開(kāi)發(fā)、提高效率而生,下面這篇文章主要給大家介紹了關(guān)于SpringBoot整合Mybatis-plus案例及用法實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • springboot中@component注解的使用實(shí)例

    springboot中@component注解的使用實(shí)例

    這篇文章主要介紹了springboot中@component注解的使用實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03

最新評(píng)論