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

Java定位問題線程解析

 更新時(shí)間:2022年11月22日 09:19:28   作者:思想永無止境  
這篇文章主要介紹了Java定位問題線程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

前言

  • ps命令的作用是顯示進(jìn)程信息的。
  • |符號(hào),是個(gè)管道符號(hào),表示左右兩邊兩個(gè)命令同時(shí)執(zhí)行。
  • grep命令是查找(Global Regular Expression Print),能使用正則表達(dá)式搜索文本,然后把匹配的行顯示出來。

命令參數(shù)如果前面的參數(shù)沒有輸入值,那么可以多個(gè)合并在一起,如-mp等同于-m -p。

grep -A -B -C 屬于上下文控制(Context control),使用規(guī)則如下:

  • grep -A 顯示匹配指定內(nèi)容及之后的n行
  • grep -B 顯示匹配指定內(nèi)容及之前的n行
  • grep -C 顯示匹配指定內(nèi)容及其前后各n行

查看是哪個(gè)進(jìn)程占用了CPU

通過top命令,查看CPU使用率高的進(jìn)程,看看COMMAND是不是java。

查看這個(gè)進(jìn)程號(hào)對(duì)應(yīng)的是哪個(gè)java程序

此步驟主要是在服務(wù)器部署多個(gè)java程序時(shí),查看進(jìn)程具體的包名,如果服務(wù)器只部署了一個(gè)jar可以忽略此步驟。

方案1

使用jps顯示所有的java應(yīng)用程序

jps -l

方案2

使用ps|grep搜索所有的java應(yīng)用程序

ps -ef|grep java

查看這個(gè)進(jìn)程中哪個(gè)線程占用了CPU 方案1,使用pidstat查看線程CPU占用率

pidstat -t -p pid

通過top獲取的pid,使用pidstat -t -p pid查詢進(jìn)程下的線程。

方案3

使用ps查看線程CPU使用時(shí)長(zhǎng)

ps -mp pid -o THREAD,tid,time

參數(shù)含義:

  • -m顯示所有的線程
  • -p pid進(jìn)程使用cpu的時(shí)間
  • -o該參數(shù)后是用戶自定義格式

將這個(gè)線程號(hào)轉(zhuǎn)16進(jìn)制(如果是java程序)

將CPU占有率高或CPU使用時(shí)間長(zhǎng)的線程號(hào)轉(zhuǎn)換為16進(jìn)制(因?yàn)楹竺娴膉stack里的線程號(hào)是16進(jìn)制),并且將其中的字母轉(zhuǎn)成小寫字母。

System.out.println(Integer.toHexString(10003999).toLowerCase());

在jstack中找到這個(gè)線程的堆棧信息

使用jstack [進(jìn)程號(hào)] 打印當(dāng)前的進(jìn)程堆棧;

jstack 39836

返回值說明:

  • prio,表示線程優(yōu)先級(jí),就是Thread中定義的線程優(yōu)先級(jí)。
  • os_prio,表示線程在操作系統(tǒng)的優(yōu)先級(jí)。
  • tid,表示Java內(nèi)的線程ID,同樣在Thread類中。
  • nid,表示線程在操作系統(tǒng)的線程ID,16進(jìn)制,我們要的就是這個(gè)。

從打印的信息中,找到之前拿到的線程號(hào)

看看這個(gè)線程在做什么

jstack 39836 | grep tid -A60 #tid為小寫的16進(jìn)制線程ID

可以將CPU占有率高的線程都看一下。

jstack打印的信息可以多關(guān)注:Java stack information for the threads listed above:,如果有發(fā)現(xiàn)Found 1 deadlock就是死鎖導(dǎo)致的。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論