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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

各种 Java Thread State 第一分析法则

發(fā)布時間:2024/8/26 java 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 各种 Java Thread State 第一分析法则 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.
用?TDA 工具,看到大量 Java Thread State 的第一反應是:
1,線程狀態(tài)為“waiting for monitor entry”: 意味著它?在等待進入一個臨界區(qū)?,所以它在”Entry Set“隊列中等待。 此時線程狀態(tài)一般都是 Blocked:
  • java.lang.Thread.State:?BLOCKED?(on object monitor)
2,線程狀態(tài)為“waiting on condition”: 說明它在等待另一個條件的發(fā)生,來把自己喚醒,或者干脆它是調用了 sleep(N)。 此時線程狀態(tài)大致為以下幾種:
  • java.lang.Thread.State:?WAITING?(parking):一直等那個條件發(fā)生;
  • java.lang.Thread.State:?TIMED_WAITING?(parking或sleeping):定時的,那個條件不到來,也將定時喚醒自己。

3,如果大量線程在“waiting for monitor entry”: 可能是一個全局鎖阻塞住了大量線程。 如果短時間內打印的 thread dump 文件反映,隨著時間流逝,waiting for monitor entry 的線程越來越多,沒有減少的趨勢,可能意味著某些線程在臨界區(qū)里呆的時間太長了,以至于越來越多新線程遲遲無法進入臨界區(qū)
4,如果大量線程在waiting on condition”: 可能是它們又跑去獲取第三方資源,尤其是第三方網絡資源,遲遲獲取不到Response,導致大量線程進入等待狀態(tài)。 所以如果你發(fā)現(xiàn)有大量的線程都處在 Wait on condition,從線程堆棧看,正等待網絡讀寫,這可能是一個網絡瓶頸的征兆,因為網絡阻塞導致線程無法執(zhí)行。 ?
線程狀態(tài)為“in Object.wait()”: 說明它獲得了監(jiān)視器之后,又調用了?java.lang.Object.wait() 方法。 每個 Monitor在某個時刻,只能被一個線程擁有,該線程就是 “Active Thread”,而其它線程都是 “Waiting Thread”,分別在兩個隊列 “ Entry Set”和 “Wait Set”里面等候。在 “Entry Set”中等待的線程狀態(tài)是 “Waiting for monitor entry”,而在 “Wait Set”中等待的線程狀態(tài)是 “in Object.wait()”。 當線程獲得了 Monitor,如果發(fā)現(xiàn)線程繼續(xù)運行的條件沒有滿足,它則調用對象(一般就是被 synchronized 的對象)的 wait() 方法,放棄了 Monitor,進入 “Wait Set”隊列。 此時線程狀態(tài)大致為以下幾種:
  • java.lang.Thread.State:?TIMED_WAITING?(on object monitor);
  • java.lang.Thread.State:?WAITING?(on object monitor);
一般都是RMI相關線程(RMI RenewClean、 GC Daemon、RMI Reaper),GC線程(Finalizer),引用對象垃圾回收線程(Reference Handler)等系統(tǒng)線程處于這種狀態(tài)。 圖1 A Java Monitor 示范一: 下面這個線程在等待這個鎖?0x00000000fe7e3b50,等待進入臨界區(qū): "RMI TCP Connection(64896)-172.16.52.118" daemon prio=10 tid=0x00000000405a6000 nid=0x68fe?waiting for monitor entry?[0x00007f2be65a3000] java.lang.Thread.State:?BLOCKED (on object monitor) at com.xyz.goods.service.impl.GoodsServiceImpl.findChanellGoodsCountWithCache(GoodsServiceImpl.java:1734) -?waiting to lock <0x00000000fe7e3b50> (a java.lang.String)
那么誰持有這個鎖呢? 是另一個先調用了?findChanellGoodsCountWithCache 函數(shù)的線程: "RMI TCP Connection(64878)-172.16.52.117" daemon prio=10 tid=0x0000000040822000 nid=0x6841 runnable [0x00007f2be76b3000] java.lang.Thread.State:?RUNNABLE at java.net.SocketInputStream.socketRead0(Native Method) at java.net.SocketInputStream.read(SocketInputStream.java:129) at java.io.BufferedInputStream.fill(BufferedInputStream.java:218) at java.io.BufferedInputStream.read1(BufferedInputStream.java:258) at java.io.BufferedInputStream.read(BufferedInputStream.java:317) - locked <0x00000000af4ed638> (a java.io.BufferedInputStream) at org.bson.io.Bits.readFully(Bits.java:35) at org.bson.io.Bits.readFully(Bits.java:28) at com.mongodb.Response.<init>(Response.java:35) at com.mongodb.DBPort.go(DBPort.java:110) - locked <0x00000000af442d48> (a com.mongodb.DBPort) at com.mongodb.DBPort.go(DBPort.java:75) - locked <0x00000000af442d48> (a com.mongodb.DBPort) at com.mongodb.DBPort.call(DBPort.java:65) at com.mongodb.DBTCPConnector.call(DBTCPConnector.java:202) at com.mongodb.DBApiLayer$MyCollection.__find(DBApiLayer.java:296) at com.mongodb.DB.command(DB.java:152) at com.mongodb.DBCollection.getCount(DBCollection.java:760) at com.mongodb.DBCollection.getCount(DBCollection.java:731) at com.mongodb.DBCollection.count(DBCollection.java:697) at com.xyz.goods.manager.MongodbManager.count(MongodbManager.java:202) at com.xyz.goods.service.impl.GoodsServiceImpl.findChanellGoodsCount(GoodsServiceImpl.java:1787) at com.xyz.goods.service.impl.GoodsServiceImpl.findChanellGoodsCountWithCache(GoodsServiceImpl.java:1739) -?locked <0x00000000fe7e3b50> (a java.lang.String) 示范二: 等待另一個條件發(fā)生來將自己喚醒: "RMI TCP Connection(idle)" daemon prio=10 tid=0x00007fd50834e800 nid=0x56b2?waiting on condition?[0x00007fd4f1a59000] ? ?java.lang.Thread.State:?TIMED_WAITING (parking) at sun.misc.Unsafe.park(Native Method) -?parking to wait for ?<0x00000000acd84de8>?(a java.util.concurrent.SynchronousQueue$TransferStack) at java.util.concurrent.locks.LockSupport.parkNanos(LockSupport.java:198) at java.util.concurrent.SynchronousQueue$TransferStack.awaitFulfill(SynchronousQueue.java:424) at java.util.concurrent.SynchronousQueue$TransferStack.transfer(SynchronousQueue.java:323) at java.util.concurrent.SynchronousQueue.poll(SynchronousQueue.java:874) at java.util.concurrent.ThreadPoolExecutor.getTask(ThreadPoolExecutor.java:945) at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:907) at java.lang.Thread.run(Thread.java:662) 1)“TIMED_WAITING (parking)”中的 timed_waiting 指等待狀態(tài),但這里指定了時間,到達指定的時間后自動退出等待狀態(tài);parking指線程處于掛起中。 2)“waiting on condition”需要與堆棧中的“parking to wait for ?<0x00000000acd84de8>?(a java.util.concurrent.SynchronousQueue$TransferStack)” 結合來看。首先,本線程肯定是在等待某個條件的發(fā)生,來把自己喚醒。其次,SynchronousQueue 并不是一個隊列,只是線程之間移交信息的機制,當我們把一個元素放入到 SynchronousQueue 中時必須有另一個線程正在等待接受移交的任務,因此這就是本線程在等待的條件。 示范三: "RMI RenewClean-[172.16.50.182:4888]" daemon prio=10 tid=0x0000000040d2c800 nid=0x97e?in Object.wait()?[0x00007f9ccafd0000] java.lang.Thread.State:?TIMED_WAITING (on object monitor) at java.lang.Object.wait(Native Method) - waiting on <0x0000000799b032d8> (a java.lang.ref.ReferenceQueue$Lock) at java.lang.ref.ReferenceQueue.remove(ReferenceQueue.java:118) - locked <0x0000000799b032d8> (a java.lang.ref.ReferenceQueue$Lock) at sun.rmi.transport.DGCClient$EndpointEntry$RenewCleanThread.run(DGCClient.java:516) at java.lang.Thread.run(Thread.java:662)

總結

以上是生活随笔為你收集整理的各种 Java Thread State 第一分析法则的全部內容,希望文章能夠幫你解決所遇到的問題。

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

主站蜘蛛池模板: 日韩国产片 | 在线观看视频91 | 成人av激情 | 337p亚洲精品色噜噜狠狠 | 日韩人妻无码精品久久免费 | 99riav国产精品视频 | 深爱婷婷网| 久久国产成人 | 国产精品海角社区 | 天天影视综合 | 国产精品系列在线播放 | 人人妻人人澡人人爽久久av | 在线观看日韩欧美 | 伊人网视频 | 久久嫩草| 成年人爱爱视频 | 久久精品视频在线播放 | 成人夜晚视频 | 国内精品久久久久久久久 | 在线黄视频| 丝袜美腿亚洲综合 | 午夜久久久久 | 欧美一区二区三区久久精品 | 亚洲精品一区二区三区中文字幕 | 国产美女引诱水电工 | 日韩极品视频在线观看 | 国产精品久久久久免费 | 日韩亚洲视频在线观看 | 久久精品久久久久久 | www.av在线播放 | www.五月婷 | 求免费黄色网址 | 色国产视频 | 日韩欧美国产成人精品免费 | 欢乐谷在线观看免费播放高清 | 日本护士╳╳╳hd少妇 | 黄色一级免费网站 | 精产国品一区二区三区 | 免费国产黄色片 | 春日野结衣av | 日本特级黄色片 | 日本一级视频 | 国产日韩成人内射视频 | 91在线一区二区三区 | 国产精品原创 | 黑人一级视频 | 欧美特级毛片 | 男女考妣视频 | 日韩精品视频免费播放 | 在线91av | 日韩一卡二卡三卡四卡 | 国产a√精品区二区三区四区 | 激情 小说 亚洲 图片 伦 | 欧美日韩激情一区二区 | 一区二区三区在线免费视频 | 久久天堂av综合合色蜜桃网 | aa片在线观看视频在线播放 | 手机av免费在线 | 一级黄在线观看 | 国产一区二区三区在线观看视频 | 国产成人中文字幕 | 91丨九色丨国产 | 污污视频网站免费观看 | 成年人免费看毛片 | 黄色三级免费 | 樱空桃在线观看 | 午夜视频在线免费播放 | 在线天堂资源 | 亚洲天堂中文在线 | 快色在线 | 美女扒开内裤让男人桶 | 综合色在线 | 香蕉视频网页 | 亚洲va久久久噜噜噜无码久久 | 男人天堂成人网 | 欧美深夜在线 | 欧美日韩中文在线 | 丁香六月天婷婷 | 一级特黄av | xxxxwww一片 | 老牛影视av牛牛影视av | 青娱乐av在线 | 大屁股白浆一区二区三区 | 亚洲人妻一区二区 | 国产精品天天av精麻传媒 | 天堂av2024| 波多野结衣大片 | 337p粉嫩大胆色噜噜狠狠图片 | 91大奶 | 日韩羞羞 | 午夜在线视频免费观看 | 一区二区成人精品 | 超碰8| 女优一区 | 99热网 | 国产精品久久久久久久久久久久久久久久久 | 欧美交| 豆国产97在线 | 亚洲 | 欧美成人精品在线视频 |