更新時間:2022-12-08 10:33:34 來源:動力節點 瀏覽3064次
相信大家對線程的基本概念已經有所了解,用Java線程并發的基本單位。在大多數情況下,應用程序的吞吐量增加當創建多個線程并行任務。
然而,總有一個飽和點。畢竟,一個應用程序的吞吐量取決于CPU和內存資源。在一定限制,增加線程的數量會導致高內存,線程上下文切換等。
所以一個好的起點在故障診斷Java應用程序中的一個高端內存問題是監控線程的數量。在本教程中,我們將看看一些方式我們可以檢查Java進程創建的線程的數量。
最簡單的方式看到Java線程的數量是使用像Java VisualVM的圖形工具。除了應用程序線程,Java VisualVM還列出了GC或任何其他線程所使用的應用程序(如JMX線程)。
此外,它還顯示了諸如線程狀態及其持續時間:
監控線程的數量是在Java VisualVM最基本的特征。一般來說,圖形工具更先進,允許應用程序的實時監控。例如,Java VisualVM允許我們樣品CPU堆棧跟蹤,從而找到一個類或方法,可能會導致CPU瓶頸。
Java VisualVM分布與JDK安裝在Windows機器上。應用程序部署在Linux上,我們需要連接到遠程應用程序。這需要JMX VM參數。
因此,這些工具不會工作,如果一個應用程序已經運行沒有這些參數。在后面的小節中,我們將看到如何使用命令行工具獲得線程的數量。
在一些用例中,我們可以找到應用程序中線程的數量。例如,顯示在日志監視儀表板或公開。
在這種情況下,我們依靠Java api的線程數。值得慶幸的是,有一個activeCount () API在線程類:
public class FindNumberofThreads {
public static void main(String[] args) {
System.out.println("Number of threads " + Thread.activeCount());
}
}
和輸出將會是:
Number of threads 2
值得注意的是,如果我們看到在Java VisualVM線程的數量,我們將會看到更多的相同的應用程序線程。這是因為activeCount()只返回線程的數量在同一ThreadGroup。Java的所有線程分為組織更容易管理。
在這個例子中,我們剛剛父ThreadGroup,即。主要:
public static void main(String[] args) {
System.out.println("Current Thread Group - " + Thread.currentThread().getThreadGroup().getName());
}
Current Thread Group - main
如果有許多線程組在Java應用程序中,activeCount()不會給一個正確的輸出。例如,它不會返回GC線程的數量。
在這樣的場景中,我們可以使用JMX API:
public static void main(String[] args) {
System.out.println("Total Number of threads " + ManagementFactory.getThreadMXBean().getThreadCount());
}
這個API返回總數從所有線程的線程組,GC, JMX,等等。
Total Number of threads 6
事實上,JMX圖形工具如Java VisualVM使用相同的API的數據。
之前,我們討論了Java VisualVM,圖形分析住線程在一個應用程序的工具。雖然生活的可視化線程是一個偉大的工具,它有一個小的影響應用程序的性能。因此不建議用于生產環境。
此外,正如我們之前所討論的,在Linux中Java VisualVM需要遠程連接。事實上,在某些情況下,它需要額外的配置。例如,一個應用程序運行在一個碼頭工人或Kubernetes需要額外的服務和端口配置。
在這種情況下,我們必須依靠命令行工具在主機環境中線程數。
幸運的是,Java提供一些命令線程轉儲。我們可以分析一個線程轉儲為一個文本文件或使用一個線程dump analyzer工具檢查線程的數量以及它們的狀態。
阿里巴巴阿爾薩斯是另一個偉大的command-l
top -H -p 1
這里,- h是一個命令行選項來顯示每個線程在一個Java進程。如果沒有這個標志,上面的命令將顯示進程中的所有線程的綜合統計。- p選項過濾器的輸出目標應用程序的進程id:
top - 15:59:44 up 7 days, 19:23, 0 users, load average: 0.52, 0.41, 0.36
Threads: 37 total, 0 running, 37 sleeping, 0 stopped, 0 zombie
%Cpu(s): 3.2 us, 2.2 sy, 0.0 ni, 93.4 id, 0.8 wa, 0.0 hi, 0.3 si, 0.0 st
MiB Mem : 1989.2 total, 110.2 free, 1183.1 used, 695.8 buff/cache
MiB Swap: 1024.0 total, 993.0 free, 31.0 used. 838.8 avail Mem
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
1 flink 20 0 2612160 304084 29784 S 0.0 14.9 0:00.07 java
275 flink 20 0 2612160 304084 29784 S 0.0 14.9 0:02.87 java
276 flink 20 0 2612160 304084 29784 S 0.0 14.9 0:00.37 VM Thread
277 flink 20 0 2612160 304084 29784 S 0.0 14.9 0:00.00 Reference Handl
278 flink 20 0 2612160 304084 29784 S 0.0 14.9 0:00.00 Finalizer
279 flink 20 0 2612160 304084 29784 S 0.0 14.9 0:00.00 Signal Dispatch
如上圖所示,它顯示了線程id,即。、PID和線程的CPU和內存使用率。類似于Java VisualVM,頂部命令將列出所有線程,包括GC, JMX或任何其他子流程。
發現我們使用的進程ID作為參數在上面的命令中,我們可以使用ps命令:
ps -ef | grep java
事實上,我們可以使用ps命令來列出線程:
ps -e -T | grep 1
t選項告訴ps命令列出所有線程開始由應用程序:
1 1 ? 00:00:00 java
1 275 ? 00:00:02 java
1 276 ? 00:00:00 VM Thread
1 277 ? 00:00:00 Reference Handl
1 278 ? 00:00:00 Finalizer
1 279 ? 00:00:00 Signal Dispatch
1 280 ? 00:00:03 C2 CompilerThre
1 281 ? 00:00:01 C1 CompilerThre
在這里,第一列是PID,第二列顯示了每個線程Linux線程ID。
在本文中,我們發現我們有許多方式可以找到Java應用程序線程的數量。在大多數情況下,使用命令行選項像頂部或ps命令應該是首選的方法。
然而,在某些情況下,我們可能還需要圖形工具如Java VisualVM。所有示例代碼都可以在GitHub。以上就是動力節點小編介紹的"告訴你在Java中如何查看線程數",希望對大家有幫助,想了解更多可查看Java多線程編程技術文檔。
0基礎 0學費 15天面授
有基礎 直達就業
業余時間 高薪轉行
工作1~3年,加薪神器
工作3~5年,晉升架構
提交申請后,顧問老師會電話與您溝通安排學習