亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

一文帶你深入解析Java應(yīng)用線程轉(zhuǎn)儲

 更新時間:2025年04月23日 10:46:59   作者:碼農(nóng)阿豪@新空間  
在Java應(yīng)用運(yùn)維和問題排查過程中,線程轉(zhuǎn)儲(Thread?Dump)是一個非常重要的工具,它能夠幫助我們了解JVM內(nèi)部線程的運(yùn)行狀態(tài),下面小編來和大家詳細(xì)介紹一下它吧

引言

在Java應(yīng)用運(yùn)維和問題排查過程中,線程轉(zhuǎn)儲(Thread Dump)是一個非常重要的工具,它能夠幫助我們了解JVM內(nèi)部線程的運(yùn)行狀態(tài),快速定位死鎖、線程阻塞、資源競爭等問題。本文將通過一個實(shí)際的線程轉(zhuǎn)儲日志案例,詳細(xì)分析其內(nèi)容,并結(jié)合代碼示例,講解如何從中發(fā)現(xiàn)問題并優(yōu)化應(yīng)用性能。

1. 什么是線程轉(zhuǎn)儲

線程轉(zhuǎn)儲是JVM在某一時刻所有線程的快照,包含每個線程的調(diào)用棧、狀態(tài)和鎖信息。通過分析線程轉(zhuǎn)儲,我們可以:

  • 檢查線程是否阻塞或死鎖。
  • 發(fā)現(xiàn)資源競爭問題。
  • 優(yōu)化線程池配置。
  • 診斷應(yīng)用響應(yīng)緩慢或崩潰的原因。

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

使用 jstack 命令(適用于運(yùn)行中的Java進(jìn)程):

jstack -l <pid> > thread_dump.log

通過 kill -3 發(fā)送信號(適用于Linux環(huán)境):

kill -3 <pid>

使用JMX工具(如VisualVM、JConsole)。

2. 案例日志分析

我們分析的日志片段如下:

2025-04-22 18:16:40
Full thread dump OpenJDK 64-Bit Server VM (25.362-b08 mixed mode):

"SIGTERM handler" #138 daemon prio=9 os_prio=0 tid=0x00007f03fc005000 nid=0xa9b06 runnable [0x00007f0438dfc000]
   java.lang.Thread.State: RUNNABLE
    at java.lang.Thread.run(Thread.java:749)

"Druid-ConnectionPool-Destroy-816944408" #137 daemon prio=5 os_prio=0 tid=0x00007f0364222000 nid=0xa9aff waiting on condition [0x00007f04385fc000]
   java.lang.Thread.State: TIMED_WAITING (sleeping)
    at java.lang.Thread.sleep(Native Method)
    at com.alibaba.druid.pool.DruidDataSource$DestroyConnectionThread.run(DruidDataSource.java:2786)
...

關(guān)鍵線程解析

(1) SIGTERM handler 線程

狀態(tài):RUNNABLE

作用:處理JVM終止信號(如 kill -15),表明應(yīng)用正在關(guān)閉。

可能的問題:如果是非預(yù)期關(guān)閉,需檢查是否有異常終止或OOM。

(2) Druid 連接池線程

Druid-ConnectionPool-Destroy-*

  • 狀態(tài):TIMED_WAITING (sleeping)
  • 作用:銷毀閑置數(shù)據(jù)庫連接。
  • 優(yōu)化建議:調(diào)整 timeBetweenEvictionRunsMillis 參數(shù),避免頻繁銷毀。

Druid-ConnectionPool-Create-*

  • 狀態(tài):WAITING (parking)
  • 作用:創(chuàng)建新數(shù)據(jù)庫連接。
  • 潛在問題:如果長期阻塞,可能是連接池耗盡,需檢查 maxActive 配置。

(3) Nacos 客戶端線程

nacos-grpc-client-executor-*

狀態(tài):TIMED_WAITING (parking)

作用:Nacos 客戶端通過gRPC與服務(wù)端通信。

排查點(diǎn):如果大量線程阻塞,可能是Nacos服務(wù)端不可達(dá)或網(wǎng)絡(luò)問題。

3. 常見問題及解決方案

3.1 線程死鎖

示例代碼:

public class DeadlockExample {
    private static final Object lock1 = new Object();
    private static final Object lock2 = new Object();

    public static void main(String[] args) {
        new Thread(() -> {
            synchronized (lock1) {
                try { Thread.sleep(100); } catch (InterruptedException e) {}
                synchronized (lock2) {
                    System.out.println("Thread 1");
                }
            }
        }).start();

        new Thread(() -> {
            synchronized (lock2) {
                synchronized (lock1) {
                    System.out.println("Thread 2");
                }
            }
        }).start();
    }
}

線程轉(zhuǎn)儲中的死鎖表現(xiàn):

Found one Java-level deadlock:
=============================
Thread 1:
  waiting to lock monitor 0x00007f03fc005000 (object 0x0000000749b623a0, a java.lang.Object),
  which is held by Thread 2

Thread 2:
  waiting to lock monitor 0x00007f03fc005100 (object 0x0000000749b623b0, a java.lang.Object),
  which is held by Thread 1

解決方案:

  • 使用 jstack 檢測死鎖。
  • 調(diào)整鎖順序,避免循環(huán)依賴。

3.2 線程池耗盡

示例代碼:

ExecutorService executor = Executors.newFixedThreadPool(2);
for (int i = 0; i < 10; i++) {
    executor.submit(() -> {
        try { Thread.sleep(1000); } catch (InterruptedException e) {}
    });
}

線程轉(zhuǎn)儲表現(xiàn):

"pool-1-thread-1" #12 prio=5 os_prio=0 tid=0x00007f03fc005000 nid=0xa9b06 waiting on condition [0x00007f0438dfc000]
   java.lang.Thread.State: WAITING (parking)

解決方案:

  • 增大線程池大小或使用 ThreadPoolExecutor 動態(tài)調(diào)整。
  • 使用有界隊(duì)列避免OOM。

3.3 數(shù)據(jù)庫連接泄漏

Druid 配置優(yōu)化:

spring:
  datasource:
    druid:
      initial-size: 5
      min-idle: 5
      max-active: 20
      max-wait: 60000
      time-between-eviction-runs-millis: 60000
      min-evictable-idle-time-millis: 300000
      validation-query: SELECT 1
      test-while-idle: true

監(jiān)控SQL泄漏:

// 在代碼中顯式關(guān)閉連接
try (Connection conn = dataSource.getConnection()) {
    // SQL操作
} // 自動關(guān)閉

4. 線程轉(zhuǎn)儲分析工具

VisualVM(可視化分析線程狀態(tài))

FastThread(在線分析工具)

Eclipse MAT(分析線程引用關(guān)系)

5. 總結(jié)

通過分析線程轉(zhuǎn)儲,我們可以:

  • 發(fā)現(xiàn)死鎖、線程阻塞等問題。
  • 優(yōu)化線程池和數(shù)據(jù)庫連接池配置。
  • 診斷應(yīng)用崩潰或性能下降的原因。

最佳實(shí)踐:

  • 定期采集線程轉(zhuǎn)儲(尤其在應(yīng)用卡頓時)。
  • 結(jié)合日志和監(jiān)控(如Prometheus + Grafana)全面分析。
  • 使用自動化工具(如Arthas)進(jìn)行動態(tài)診斷。

到此這篇關(guān)于一文帶你深入解析Java應(yīng)用線程轉(zhuǎn)儲的文章就介紹到這了,更多相關(guān)Java線程轉(zhuǎn)儲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MyBatis中使用分頁插件PageHelper實(shí)現(xiàn)分頁功能

    MyBatis中使用分頁插件PageHelper實(shí)現(xiàn)分頁功能

    分頁是經(jīng)常使用的功能,本文主要介紹了Mybatis中處理特殊SQL處理邏輯,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • 如何把idea中的項(xiàng)目導(dǎo)入github倉庫中(圖文詳解)

    如何把idea中的項(xiàng)目導(dǎo)入github倉庫中(圖文詳解)

    這篇文章主要介紹了如何把idea中的項(xiàng)目導(dǎo)入github倉庫中,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-07-07
  • springcloud 熔斷監(jiān)控Hystrix Dashboard和Turbine

    springcloud 熔斷監(jiān)控Hystrix Dashboard和Turbine

    這篇文章主要介紹了springcloud 熔斷監(jiān)控Hystrix Dashboard和Turbine,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • Spring Security實(shí)現(xiàn)動態(tài)路由權(quán)限控制方式

    Spring Security實(shí)現(xiàn)動態(tài)路由權(quán)限控制方式

    這篇文章主要介紹了Spring Security實(shí)現(xiàn)動態(tài)路由權(quán)限控制方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • idea創(chuàng)建項(xiàng)目沒有webapp文件夾的解決方法

    idea創(chuàng)建項(xiàng)目沒有webapp文件夾的解決方法

    本文主要介紹了idea創(chuàng)建項(xiàng)目沒有webapp文件夾的解決方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Java實(shí)現(xiàn)兩個日期相減等于天數(shù)

    Java實(shí)現(xiàn)兩個日期相減等于天數(shù)

    這篇文章主要介紹了Java兩個日期相減等于天數(shù)的實(shí)現(xiàn)方式,本文通過兩種方式結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • SpringBoot靜態(tài)資源css,js,img配置方案

    SpringBoot靜態(tài)資源css,js,img配置方案

    這篇文章主要介紹了SpringBoot靜態(tài)資源css,js,img配置方案,下文給大家分享了三種解決方案,需要的朋友可以參考下
    2017-07-07
  • 東八區(qū)springboot如何配置序列化

    東八區(qū)springboot如何配置序列化

    本文主要介紹了東八區(qū)springboot如何配置序列化,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • Spring boot實(shí)現(xiàn)一個簡單的ioc(2)

    Spring boot實(shí)現(xiàn)一個簡單的ioc(2)

    這篇文章主要為大家詳細(xì)介紹了Spring boot實(shí)現(xiàn)一個簡單ioc的第二篇,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • 詳解Maven settings.xml配置(指定本地倉庫、阿里云鏡像設(shè)置)

    詳解Maven settings.xml配置(指定本地倉庫、阿里云鏡像設(shè)置)

    這篇文章主要介紹了詳解Maven settings.xml配置(指定本地倉庫、阿里云鏡像設(shè)置),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-12-12

最新評論