欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

如何獲取Java的線程轉(zhuǎn)儲-創(chuàng)新互聯(lián)

如何獲取Java的線程轉(zhuǎn)儲?相信很多沒有經(jīng)驗(yàn)的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

只為您設(shè)計(jì)更接底氣、較有營銷力的好網(wǎng)站,將營銷策劃與網(wǎng)頁設(shè)計(jì)互相結(jié)合的專業(yè)機(jī)構(gòu),網(wǎng)絡(luò)營銷推廣公司中較早掌握H5建站技術(shù)的機(jī)構(gòu)。一個好的成都品牌網(wǎng)站建設(shè),不能只是一張名片,茫茫網(wǎng)海,想要快速吸引到您客戶的眼球,必須全方位的展現(xiàn)出企業(yè)突出的優(yōu)勢,以求達(dá)到主動營銷的效果,最終促成成交!

1. 線程轉(zhuǎn)儲簡介

線程轉(zhuǎn)儲(Thread Dump)就是JVM中所有線程狀態(tài)信息的一次快照。

線程轉(zhuǎn)儲一般使用文本格式, 可以將其保存到文本文件中, 然后人工查看和分析, 或者使用工具/API自動分析。

Java中的線程模型, 直接使用了操作系統(tǒng)的線程調(diào)度模型, 只進(jìn)行簡單的封裝。

線程調(diào)用棧, 也稱為方法調(diào)用棧。 比如在程序執(zhí)行過程中, 有一連串的方法調(diào)用鏈:obj1.method2調(diào)用了obj2.methodB,obj2.methodB又調(diào)用了obj3.methodC。 每個線程的狀態(tài)都可以通過這種調(diào)用棧來表示。

線程轉(zhuǎn)儲展示了各個線程的行為, 對于診斷和排查問題非常有用。

下面我們通過具體示例, 來演示各種獲取Java線程轉(zhuǎn)儲的工具, 以及使用方法。

2. 使用JDK自帶的工具

我們一般使用JDK自帶的命令行工具來獲取Java應(yīng)用程序的線程轉(zhuǎn)儲。 這些工具都在JDK主目錄的bin文件夾下。

所以, 只要配置好 PATH 路徑即可。 如果不會配置, 可以參考:JDK環(huán)境準(zhǔn)備

2.1 jstack 工具

jstack 是JDK內(nèi)置的一款命令行工具, 專門用來查看線程狀態(tài), 也可以用來執(zhí)行線程轉(zhuǎn)儲。

一般先通過jps或者ps命令找到Java進(jìn)程對應(yīng)的pid, 然后在控制臺中通過pid來輸出線程轉(zhuǎn)儲。 當(dāng)然, 我們也可以將輸出內(nèi)容重定向到某個文件中。

使用jstack工具獲取線程轉(zhuǎn)儲的基本參數(shù)格式為:

jstack [-F] [-l] [-m] <pid>

下面請看具體的演示:

# 1. 查看幫助信息
jstack -help

輸出的內(nèi)容類似于:

Usage:
 jstack [-l] <pid>
  (to connect to running process)
 jstack -F [-m] [-l] <pid>
  (to connect to a hung process)
 jstack [-m] [-l] <executable> <core>
  (to connect to a core file)
 jstack [-m] [-l] [server_id@]<remote server IP or hostname>
  (to connect to a remote debug server)

Options:
 -F to force a thread dump. Use when jstack <pid> does not respond (process is hung)
 -m to print both java and native frames (mixed mode)
 -l long listing. Prints additional information about locks
 -h or -help to print this help message

對應(yīng)的參數(shù)選項(xiàng)是可選的。 具體含義如下:

  • -F選項(xiàng), 強(qiáng)制執(zhí)行線程轉(zhuǎn)儲; 有時候jstack pid會假死, 則可以加上-F標(biāo)志

  • -l選項(xiàng), 會查找堆內(nèi)存中擁有的同步器以及資源鎖

  • -m選項(xiàng), 額外打印 native棧幀(C和C++的)

例如, 獲取線程轉(zhuǎn)儲并將結(jié)果輸出到文件:

jstack -F 17264 > /tmp/threaddump.txt

使用jps命令可以獲取本地Java進(jìn)程的 pid。

2.2 Java Mission Control

Java Mission Control(JMC)是一款客戶端圖形界面工具, 用于收集和分析Java應(yīng)用程序的各種數(shù)據(jù)。

啟動JMC后, 首先會顯示本地計(jì)算機(jī)上運(yùn)行的Java進(jìn)程列表。 當(dāng)然也可以通過JMC連接到遠(yuǎn)程Java進(jìn)程。

可以鼠標(biāo)右鍵單擊對應(yīng)的進(jìn)程, 選擇 “Start Flight Recording(開始飛行記錄)” 。 結(jié)束之后, “Threads(線程)” 選項(xiàng)卡會顯示“線程轉(zhuǎn)儲”:

如何獲取Java的線程轉(zhuǎn)儲

2.3 jvisualvm

jvisualvm 是一款客戶端圖形界面工具, 既簡單又實(shí)用, 可用來監(jiān)控 Java應(yīng)用程序, 對JVM進(jìn)行故障排查和性能分析。

也可以用來獲取線程轉(zhuǎn)儲。 鼠標(biāo)右鍵單擊Java進(jìn)程, 選擇“ Thread Dump”選項(xiàng), 則可以創(chuàng)建線程轉(zhuǎn)儲, 完成后會在新選項(xiàng)卡中自動打開:

如何獲取Java的線程轉(zhuǎn)儲

2.4 jcmd

jcmd工具本質(zhì)上是向目標(biāo)JVM發(fā)送一串命令。 盡管支持很多功能, 但不支持連接遠(yuǎn)程JVM - 只能在Java進(jìn)程的本地機(jī)器上使用。

其中一個命令是Thread.print, 用來獲取線程轉(zhuǎn)儲, 示例用法如下:

jcmd 17264 Thread.print

2.5 jconsole

jconsole 工具也可以查看線程棧跟蹤。

打開jconsole并連接到正在運(yùn)行的Java進(jìn)程, 導(dǎo)航到“線程”選項(xiàng)卡, 可以查看每個線程的堆棧跟蹤:

如何獲取Java的線程轉(zhuǎn)儲

2.6 小結(jié)

事實(shí)證明, 可以使用JDK中的很多工具來獲取線程轉(zhuǎn)儲。 讓我們回顧一下, 并總結(jié)它們的優(yōu)缺點(diǎn):

jstack
jmc
jvisualvm
jcmd
jconsole

3. 使用Linux命令

在企業(yè)應(yīng)用服務(wù)器中, 出于安全原因, 可能只安裝了 JRE。 這時候沒法使用這些JDK內(nèi)置的工具。

但還是有辦法獲取線程轉(zhuǎn)儲。

3.1 使用kill -3指令

在Unix/Linux之類的系統(tǒng)中, 可以使用kill命令獲取線程轉(zhuǎn)儲, 底層實(shí)現(xiàn)原理, 則是通過系統(tǒng)調(diào)用kill()將信號參數(shù)發(fā)送給進(jìn)程。 這里需要發(fā)送的是-3信號。

一般先通過jps找到JAVA進(jìn)程對應(yīng)的pid,kill -3使用示例如下:

kill -3 17264

3.2Ctrl + Break(Windows)

在Windows操作系統(tǒng)的命令行窗口中, 可使用組合鍵Ctrl + Break來獲取線程轉(zhuǎn)儲。 當(dāng)然, 需要先導(dǎo)航至啟動Java程序的控制臺窗口, 然后同時按下CTRL鍵和Break鍵。

需要注意的是, 某些鍵盤是沒有 “Break” 鍵的。

在這種情況下, 可以組合使用CTRL,SHIFT, 以及Pause鍵。

這兩個命令都可以將線程轉(zhuǎn)儲打印到控制臺。

4. 通過編程方式使用ThreadMxBean

JMX技術(shù)支持各種各樣的花式操作。 可通過ThreadMxBean來執(zhí)行線程轉(zhuǎn)儲。

示例代碼如下:

private static String threadDump(boolean lockedMonitors, boolean lockedSynchronizers) {
 
 StringBuffer threadDump = new StringBuffer(System.lineSeparator());
 ThreadMXBean threadMXBean = ManagementFactory.getThreadMXBean();
 for(ThreadInfo threadInfo : threadMXBean.dumpAllThreads(lockedMonitors, lockedSynchronizers)) {
 
  threadDump.append(threadInfo.toString());
 }
 return threadDump.toString();
}

上面代碼做的事情很簡單, 先通過ManagementFactory獲取ThreadMxBean對象。

方法的布爾參數(shù)lockedMonitorslockedSynchronizers, 表示是否導(dǎo)出持有的同步器和管程鎖。

看完上述內(nèi)容,你們掌握如何獲取Java的線程轉(zhuǎn)儲的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

文章題目:如何獲取Java的線程轉(zhuǎn)儲-創(chuàng)新互聯(lián)
文章路徑:http://chinadenli.net/article32/dgpgsc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)商城網(wǎng)站、動態(tài)網(wǎng)站網(wǎng)站設(shè)計(jì)公司、小程序開發(fā)網(wǎng)站維護(hù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司