1. 程式人生 > >window 查詢 java 程序中佔用cpu比較高的執行緒

window 查詢 java 程序中佔用cpu比較高的執行緒

概述

公司內部的一個產品 (java 開發的) 執行在 window 虛擬機器上,執行一段時間後CPU飆升,然後想檢視是哪個執行緒佔用。
折騰了一下午,終於定位到該執行緒。

下面我們通過兩種方式定位到佔用cpu比較高的執行緒。
* 1. 使用Process Explorer,第三方工具定位,使用比較簡單,容易上手。
* 2. 使用window自帶的perfmon 效能監控工具進行監控,功能強大,但稍微有點複雜。

示例程式

public class ThreadCpuTest {
    public static void main(String[] args) {
        Thread busyTask = new
Thread(() -> { for (;;) { double a = new Random().nextDouble(); double b = new Random().nextDouble(); double c = a * b; } }); busyTask.setName("busy task"); busyTask.start(); Thread lazyTask = new
Thread(() -> { for (;;) { try { TimeUnit.SECONDS.sleep(1); } catch (Exception e) { e.printStackTrace(); } } }); busyTask.setName("lazy task"); lazyTask.start(); } }

執行該示例,然後使用監控工具定位到那個執行緒CPU使用率高。

1. Process Explorer 使用

  • 第一步: 獲得該程式的程序ID


通過 jps 可以檢視到 我們執行的程式的程序號為 “11964”

  • 第二步: 開啟Process Explorer工具

下面我們通過 Process Explorer 工具進行檢視 該程序中所有的執行緒。

開啟Process Explorer 後,介面如下:

  • 第三步: 查詢程序號為“11964”的程序

通過 jps 命令檢視的程序號為 “11964”。然後在 Process Explorer中找到該程序。

  • 第四步: 開啟該程序Properties介面
    然後選中該程序,雙擊或右鍵 選擇“Properties…”

  • 第五步: 選中“Threads”標籤頁,檢視執行緒統計資訊

    選中 Threads 標籤頁。
    發現執行緒ID為“20024” 的執行緒佔用cpu比較高。

  • 第六步: 執行緒ID轉換成十六進位制
    然後我們把 十進位制的 “20024” 轉換為 十六進位制的“4E38”。

  • 第七步: dump執行緒資訊
    jstack 11964 > thread_dump.txt

  • 第八步: 查詢執行緒ID為“4E38”的執行緒

從執行緒的名字中,我們發現該執行緒的名字是“busy_task”。

然後就可以找到該執行緒,檢視該執行緒是什麼原因大量佔用CPU,剩下的就是改程式的事情了

2. Perfmon 使用

  • 第一步: 首先使用 jps 獲取當前程式執行的程序ID

    程序ID:“8880”

  • 第二步: 開啟perfmon 效能監視器

  • 第三步: 開啟新增計數器頁面

  • 第四步: 新增計數器

    在左上部分找中,到Thread,選中 %Processor TimeID Thread 兩個選項。
    在左下部分中(選定物件的例項),找到所有“javaw”選中,點選新增按鈕,然後顯示如右半部分效果。

  • 第五步: 切換報告顯示方式

  • 第六步: 查詢使用CPU比較高的執行緒

    從圖中發現執行緒ID為“10320”的執行緒,佔用CPU比較高。

  • 第七步: 執行緒ID 轉換成十六進位制

    執行緒ID 轉換成十六進位制為“2850”

  • 第八步: dump 執行緒資訊

  • 第九步: 查詢執行緒ID為“2850”的執行緒

從執行緒堆疊資訊中可以看出該執行緒為“busy_task”執行緒。

想了解更多精彩內容請關注我的公眾號