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

如何通過jstack命令dump線程信息

 更新時(shí)間:2020年07月22日 08:33:13   作者:草木物語  
這篇文章主要介紹了如何通過jstack命令dump線程信息,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下

鎖是個(gè)非常有用的工具,運(yùn)用場(chǎng)景非常多,因?yàn)樗褂闷饋矸浅:?jiǎn)單,而且易于理解。但同時(shí)它也會(huì)帶來一些困擾,那就是可能會(huì)引起死鎖,一旦產(chǎn)生死鎖,就會(huì)造成系統(tǒng)功能不可用。讓我們先來看一段代碼,這段代碼會(huì)引起死鎖,使線程t1和線程t2互相等待對(duì)方釋放鎖。

class DeadLockDemo {
  private static String A = "A";
  private static String B = "B";

  public static void main(String[] args) {
    new DeadLockDemo().deadLock();
  }

  private void deadLock() {

    Thread t1 = new Thread(new Runnable() {
      @Override
      public void run() {
        synchronized (A) {
          try {
            Thread.currentThread().sleep(2000);
          } catch (InterruptedException e) {
            e.printStackTrace();
          }
          synchronized (B) {
            System.out.println("1");
          }
        }
      }
    });

    Thread t2 = new Thread(new Runnable() {
      @Override
      public void run() {
        synchronized (B) {
          synchronized (A) {
            System.out.println("2");
          }
        }
      }
    });

    t1.start();
    t2.start();

  }
}

這段代碼只是演示死鎖的場(chǎng)景,在現(xiàn)實(shí)中你可能不會(huì)寫出這樣的代碼。但是,在一些更為復(fù)雜的場(chǎng)景中,你可能會(huì)遇到這樣的問題,比如t1拿到鎖之后,因?yàn)橐恍┊惓G闆r沒有釋放鎖(死循環(huán))。又或者是t1拿到一個(gè)數(shù)據(jù)庫(kù)鎖,釋放鎖的時(shí)候拋出了異常,沒釋放掉。

一旦出現(xiàn)死鎖,業(yè)務(wù)是可感知的,因?yàn)椴荒芾^續(xù)提供服務(wù)了,那么只能通過dump線程查看到底是哪個(gè)線程出現(xiàn)了問題,以下線程信息告訴我們是"b1_2死鎖"類的第37行和第26行引起的死鎖。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論