日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > windows >内容正文

windows

window 查找 java 进程中占用cpu比较高的线程

發布時間:2024/9/30 windows 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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 ,點擊下面連接,進行下載。
點擊 https://docs.microsoft.com/zh-cn/sysinternals/downloads/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”線程。


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

總結

以上是生活随笔為你收集整理的window 查找 java 进程中占用cpu比较高的线程的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。