Java飛行記錄器JFR功能實現(xiàn)過程圖解
JFR
如果要深入分析問題,可以選擇使用內(nèi)置的Java飛行記錄器:Java Mission Control。
轉(zhuǎn)儲JFR需要三步:
1. 創(chuàng)建一個包含了你自己配置的JFR模板文件。運行jmc, 然后Window->Flight Recording Template Manage菜單。準備好檔案后,就可以導(dǎo)出文件,并移動到要排查問題的環(huán)境中。
2. 由于JFR需要JDK的商業(yè)證書,這一步需要解鎖jdk的商業(yè)特性。
C:Userslenovo>jcmd 8152 VM.unlock_commercial_features
3. 最后你就可以啟動JFR。
jcmd <PID> JFR.start name=test duration=60s settings=template.jfc filename=output.jfr
上述命令立即啟動JFR并開始使用templayte.jfc的配置收集60s的JVM信息,輸出到output.jfr中。
一旦記錄完成之后,就可以復(fù)制.jfr文件到你的工作環(huán)境使用jmc GUI來分析。它幾乎包含了排查jvm問題需要的所有信息,包括堆dump時的異常信息。
還有一種方式:
在JVM的啟動參數(shù)中增加如下參數(shù):
-XX:+UnlockCommercialFeatures -XX:+FlightRecorder
一分鐘后可查看記錄數(shù)據(jù),通過這些數(shù)據(jù),可以清楚的了解到這一分鐘時間內(nèi),整個操作系統(tǒng)以及JVM的所有數(shù)據(jù)情況。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. python 基于Appium控制多設(shè)備并行執(zhí)行2. JavaEE SpringMyBatis是什么? 它和Hibernate的區(qū)別及如何配置MyBatis3. Python 忽略文件名編碼的方法4. android studio實現(xiàn)簡單的計算器(無bug)5. Java Media Framework 基礎(chǔ)教程6. 解決vue頁面刷新,數(shù)據(jù)丟失的問題7. python 實現(xiàn)圍棋游戲(純tkinter gui)8. python 讀txt文件,按‘,’分割每行數(shù)據(jù)操作9. 在Mac中配置Python虛擬環(huán)境過程解析10. Python趣味挑戰(zhàn)之用pygame實現(xiàn)簡單的金幣旋轉(zhuǎn)效果
