精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

記一次 .NET 某工廠無人車調(diào)度系統(tǒng) 線程爆高分析

開發(fā) 前端
從卦中可以看到大概有12w的積壓。上面就是我的完整分析思路,最后就是告訴朋友最好的辦法就是去掉多余累贅的 SemaphoreSlim? ,直接用同步的方式執(zhí)行 Interlocked.Increment(ref serial) 即可,簡單粗暴。

一:背景

1. 講故事

前些天有位朋友找到我,說他程序中的線程數(shù)爆高,讓我?guī)兔聪略趺椿厥?,這種線程數(shù)爆高的情況找問題相對比較容易,就讓朋友丟一個dump給我,看看便知。

二:為什么會爆高

1. 查看托管線程

別人說的話不一定是真,得自己拿數(shù)據(jù)出來說話,可以用  !t 命令觀察一下便知。

0:000> !t
ThreadCount:      4683
UnstartedThread:  0
BackgroundThread: 4663
PendingThread:    0
DeadThread:       19
Hosted Runtime:   no
                                                                                                            Lock  
 DBG   ID     OSID ThreadOBJ           State GC Mode     GC Alloc Context                  Domain           Count Apt Exception
   0    1     cc44 00000268048778C0  202a020 Preemptive  0000000000000000:0000000000000000 00000268048c6d50 -00001 MTA 
   ...
4670 4679     51bc 0000026D143F0420  302b220 Preemptive  0000000000000000:0000000000000000 00000268048c6d50 -00001 MTA (Threadpool Worker) 
4671 4680     3a68 0000026D143F52E0  302b220 Preemptive  0000000000000000:0000000000000000 00000268048c6d50 -00001 MTA (Threadpool Worker) 
4672 4681     337c 0000026D143F1140  302b220 Preemptive  0000026A88AAF5B8:0000026A88AB08D0 00000268048c6d50 -00001 MTA (Threadpool Worker) 
4673 4682    188d4 0000026D143F0AB0  302b220 Preemptive  000002698881A760:000002698881C0B8 00000268048c6d50 -00001 MTA (Threadpool Worker) 
4674 4683     4bcc 0000026D143EF700  302b220 Preemptive  0000026B889C4488:0000026B889C5E18 00000268048c6d50 -00001 MTA (Threadpool Worker)

從卦中信息看確實有 4600+ 的線程,說明確實存在問題,接下來用 ~*e !clrstack 觀察每一個線程都在做什么,線程太多沒法全部輸出完畢,不過很容易的看到有大量的線程卡在 RoutingService.Push 上,截圖如下:

圖片圖片

接下來就是觀察下這個 Push 方法的邏輯,發(fā)現(xiàn)卡死在 Result 上,整理后的代碼大概如下:

private readonly SemaphoreSlim slim = new SemaphoreSlim(1, 1);

public void Push(string xxx, xxx xxx)
{
    int num = (xxx.Serial = GetSerial().Result);
}

private async Task<int> GetSerial()
{
    await slim.WaitAsync();
    try
    {
        Interlocked.Increment(ref serial);
    }
    finally
    {
        slim.Release();
    }
    return serial;
}

上面的代碼看起來挺奇葩的,為什么 GetSerial() 中不直接用 Interlocked.Increment() 呢?套一個 SemaphoreSlim 顯得非常多余。

先不管多余不多余,既然 Result 得不到值,就說明這個異步方法得不到完成,那為什么得不到完成呢?

2. 為什么異步得不到完成

熟悉 SemaphoreSlim.WaitAsync() 的朋友應該知道,這里涉及不到異步IO,所以這個是假異步,本質(zhì)上就是動態(tài)生成了一個串聯(lián)的 Task<bool>,要想知道得不到完成的根本原因,還得要挖一挖此時的 slim 信號量情況。

0:000> !do 000002690664b5a0
Name:        System.Threading.SemaphoreSlim
MethodTable: 00007ff894e56fc0
EEClass:     00007ff894e3f230
Tracked Type: false
Size:        64(0x40) bytes
File:        D:\xxx\System.Private.CoreLib.dll
Fields:
              MT    Field   Offset                 Type VT     Attr            Value Name
00007ff8948094b0  4000c2e       28         System.Int32  1 instance                0 m_currentCount
00007ff8948094b0  4000c2f       2c         System.Int32  1 instance                1 m_maxCount
00007ff8948094b0  4000c30       30         System.Int32  1 instance                0 m_waitCount
00007ff8948094b0  4000c31       34         System.Int32  1 instance                0 m_countOfWaitersPulsedToWake
00007ff8962871e0  4000c32        8 ...Private.CoreLib]]  0 instance 000002690664b5e0 m_lockObjAndDisposed
00007ff894e555f0  4000c33       10 ....ManualResetEvent  0 instance 0000000000000000 m_waitHandle
00007ff894e57870  4000c34       18 ...horeSlim+TaskNode  0 instance 0000026b86919a30 m_asyncHead
00007ff894e57870  4000c35       20 ...horeSlim+TaskNode  0 instance 0000026b889c4378 m_asyncTail
00007ff894a4a1f0  4000c36      888 ...Private.CoreLib]]  0   static 00000268864f83a0 s_cancellationTokenCanceledEventHandler

從卦中看當前的 m_currentCount=0,表明當前的信號量被消費完了,所以其他的線程都在等待就能很好理解,接下來的問題是那個從 1->0 的持有線程為什么不歸還?這個就比較難搞了,可以從如下兩個思路思考:

  • 觀察 Result

首先懷疑是不是 Result 引發(fā)的死鎖,用 !eeversion 看了下是 asp.net core ,并沒有所謂的同步上下文,所以這個問題不存在。

0:000> !eeversion
6.0.2023.32017 free
6,0,2023,32017 @Commit: a08d9ce2caf02455c0b825bcdc32974bdf769a80
Server mode with 8 gc heaps
SOS Version: 7.0.8.30602 retail build
  • 觀察代碼

因為 SemaphoreSlim 并不記錄持有線程,windbg 在這里就起不到很好的效果,不過仔細閱讀代碼,發(fā)現(xiàn)應該將 await slim.WaitAsync(); 放到 try 中更合理一點,否則無法保證 WaitAsync 和 Release 一定是成雙成對的,截圖如下:

圖片圖片

3. 什么時候開始阻塞的

仔細觀察這個 GetSerial 方法,看看里面的 serial 值就知道大概是進行到哪一步才出的問題。

0:4674> !DumpObj /d 000002690664b258
Name:        xxx.RoutingService
MethodTable: 00007ff895283ed0
EEClass:     00007ff89526ae08
Tracked Type: false
Size:        112(0x70) bytes
File:        D:\xxx\xxx.dll
Fields:
              MT    Field   Offset                 Type VT     Attr            Value Name
...
00007ff894e56fc0  4000214       48 ...ing.SemaphoreSlim  0 instance 000002690664b5a0 slim
00007ff8948094b0  4000215       60         System.Int32  1 instance             9061 serial

從卦中看已經(jīng)自增到了 9061 ,然后因為某種原因?qū)е聎ait 和 release 不匹配了,像這種情況線程池也會有大量的任務積壓,可以用 !tp 觀察下。

0:4674> !tp
logStart: 33
logSize: 200
CPU utilization: 22 %
Worker Thread: Total: 4652 Running: 4652 Idle: 0 MaxLimit: 32767 MinLimit: 8
Work Request in Queue: 0
--------------------------------------
Number of Timers: 1
--------------------------------------
Completion Port Thread:Total: 2 Free: 2 MaxFree: 16 CurrentLimit: 2 MaxLimit: 1000 MinLimit: 8

細心的朋友會發(fā)現(xiàn)這里的 Work Request in Queue: 0 ,既然是 0 何來積壓?其實這是 sos 的bug,我們需要自己到線程池隊列中提取,從當前的線程棧上尋找 ThreadPoolWorkQueue 對象即可。

0:4674> !dso
OS Thread Id: 0x4bcc (4674)
000000EF384FF5C8 0000026b06544848 System.Threading.ThreadPoolWorkQueue

0:4674> !DumpObj /d 0000026b06544848
Name:        System.Threading.ThreadPoolWorkQueue
MethodTable: 00007ff894e59d80
EEClass:     00007ff894ee01d0
Tracked Type: false
Size:        168(0xa8) bytes
File:        D:\xxx\System.Private.CoreLib.dll
Fields:
              MT    Field   Offset                 Type VT     Attr            Value Name
00007ff89476bf38  4000c61       18       System.Boolean  1 instance                0 loggingEnabled
00007ff89476bf38  4000c62       19       System.Boolean  1 instance                0 _dispatchTimeSensitiveWorkFirst
00007ff89637fc20  4000c63        8 ...Private.CoreLib]]  0 instance 0000026b065448f0 workItems
00007ff89637fe00  4000c64       10 ...Private.CoreLib]]  0 instance 0000026b06544930 timeSensitiveWorkQueue
00007ff894e59d10  4000c65       20 ...acheLineSeparated  1 instance 0000026b06544868 _separated

0:4674> !ext dcq 0000026b065448f0
System.Collections.Concurrent.ConcurrentQueue<System.Object>
   1 - dumpobj 0x0000026806c782f8
...
119419 - dumpobj 0x000002690a097658
119420 - dumpobj 0x000002690a097810
119421 - dumpobj 0x000002690a0981a8
---------------------------------------------
119421 items

從卦中可以看到大概有12w的積壓。上面就是我的完整分析思路,最后就是告訴朋友最好的辦法就是去掉多余累贅的 SemaphoreSlim ,直接用同步的方式執(zhí)行 Interlocked.Increment(ref serial) 即可,簡單粗暴。

三:總結(jié)

這次線程爆高的事故原因還是挺有意思的,用了一個雙同步來獲取 serial 值,感覺像是一種聰明反被聰明誤,代碼一定要簡單粗暴,代碼越少bug越少。

責任編輯:武曉燕 來源: 一線碼農(nóng)聊技術(shù)
相關(guān)推薦

2024-08-08 11:21:01

2021-10-27 07:30:32

.NETCPU論壇

2023-05-12 17:42:22

CPUMES系統(tǒng)

2022-10-24 07:48:37

.NETCPUGC

2024-03-15 15:15:53

.NETCPU系統(tǒng)

2021-05-17 07:43:06

Web站 CPU.NET

2023-07-31 22:29:20

CPU.NETAPI

2024-12-31 09:36:06

2021-04-21 07:38:41

CPU游戲站程序

2024-06-13 17:09:55

2023-05-08 08:25:52

2024-03-28 12:56:36

2023-04-06 10:52:18

2024-03-26 00:44:53

.NETCIM系統(tǒng)

2023-03-26 20:24:50

ERP網(wǎng)站系統(tǒng)

2024-07-09 11:51:20

Windows線程池源碼

2024-07-01 13:00:24

.NET網(wǎng)絡邊緣計算

2022-01-17 21:28:36

管理系統(tǒng).NET

2024-11-29 10:06:59

2025-10-29 01:11:00

.NET系統(tǒng)windows
點贊
收藏

51CTO技術(shù)棧公眾號

日本福利一区二区| 久久久久久一级片| 亚州av一区二区| 懂色av蜜桃av| theporn国产在线精品| 欧美色视频日本版| 欧洲精品视频在线| 欧美人体大胆444www| 久久国产精品色婷婷| 欧美国产亚洲视频| 91社区视频在线观看| 国产精品流白浆在线观看| 色播五月激情综合网| av磁力番号网| 国产精品麻豆一区二区三区| 国产馆精品极品| 国产精品久久久久久久久借妻 | 亚洲精品成人电影| 老司机午夜精品视频在线观看| 欧美精品亚州精品| 九一在线免费观看| 亚洲春色h网| 精品对白一区国产伦| 天天影视色综合| 成人免费网站www网站高清| 亚洲国产乱码最新视频 | 痴汉一区二区三区| 亚洲天堂国产精品| 日韩专区在线视频| 57pao精品| 6080国产精品一区二区| 国产在线拍偷自揄拍精品| 日韩欧美大片在线观看| 91精品动漫在线观看| 亚洲天堂影视av| 国产麻豆天美果冻无码视频 | 一本一道久久综合狠狠老精东影业| 中文字幕成人精品久久不卡| 好吊一区二区三区视频| 7m精品国产导航在线| 69精品人人人人| 在线看免费毛片| 日韩久久一区| 在线观看网站黄不卡| 男女激情无遮挡| 国产第一页在线视频| 亚洲人成网站精品片在线观看| 亚洲精品一品区二品区三品区| 你懂的视频在线| 久久日韩粉嫩一区二区三区| 久久久婷婷一区二区三区不卡| 日韩中文字幕观看| 波多野结衣中文字幕一区二区三区| 亚洲成人99| 精品捆绑美女sm三区 | av在线不卡精品| 在线视频亚洲一区| 日本在线观看免费视频| jizz免费一区二区三区| 欧美日韩一区小说| 午夜免费福利视频在线观看| 日韩三级成人| 91精品国产综合久久香蕉麻豆| 超碰超碰在线观看| 91国产一区| 日韩一区二区在线免费观看| 黄页网站在线看| 精品久久ai电影| 亚洲欧美日韩精品| 少妇av片在线观看| 性欧美欧美巨大69| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产精品久久久久久久精| 极品少妇一区二区三区| 91禁外国网站| 国产又粗又猛又黄视频| 蜜乳av一区二区三区| 亚洲一区亚洲二区| 手机av在线免费观看| 国产色一区二区| 99re99热| 97人人爽人人澡人人精品| 欧美性猛交丰臀xxxxx网站| 最新天堂中文在线| 成人三级av在线| 国产亚洲精品成人av久久ww| 潘金莲一级黄色片| 伊人久久亚洲热| 国产精品欧美日韩| 亚洲精品一区二区三区区别 | 精品国产乱码久久久久久图片| 欧美三级视频在线观看| 亚洲精品中文综合第一页| fc2ppv国产精品久久| 午夜欧美视频在线观看| 男女男精品视频站| avtt综合网| 中文日韩在线观看| 精品无码久久久久久久| 天堂一区二区在线免费观看| 69174成人网| 精品无吗乱吗av国产爱色| 亚洲人成精品久久久久久| 男人靠女人免费视频网站| 96sao精品免费视频观看| 日韩高清中文字幕| 国产成人无码aa精品一区| 久久精品二区三区| 国产精品久久精品国产| 自拍视频在线网| 欧美日韩精品在线视频| 97人人模人人爽人人澡| 国产一区二区三区日韩精品 | 三级在线观看视频| 欧美一级夜夜爽| 污污视频网站在线免费观看| 国产欧美一级| 成人在线免费观看一区| 亚乱亚乱亚洲乱妇| 色久优优欧美色久优优| 国产麻豆剧传媒精品国产av| 亚洲综合色网| 国产精品人成电影| 黄色在线播放| 欧美日韩午夜视频在线观看| 国产伦精品一区二区三区88av| 久久人体视频| 国产精品青草久久久久福利99| 国产精品国产高清国产| 亚洲国产日韩a在线播放性色| 国内自拍第二页| 欧美mv日韩| 国产精品国模在线| 国产中文在线视频| 波多野结衣在线播放一区| 国产成人午夜精品5599 | 成人羞羞网站入口免费| 热99精品只有里视频精品| 亚州av在线播放| 午夜精品国产更新| 国产草草浮力影院| 亚洲区一区二| 狠狠色伊人亚洲综合网站色| heyzo高清中文字幕在线| 欧美成人激情免费网| 丁香花五月激情| 国产v日产∨综合v精品视频| 欧美日韩中文字幕在线播放| 日韩精品一区二区三区中文在线 | 国产一区二区三区久久久| 一本一生久久a久久精品综合蜜| 国产91在线播放精品| 中文字幕日韩视频| 一级α片免费看刺激高潮视频| 国产精品亲子伦对白| 亚洲美女性囗交| 欧美精品福利| 精品国产免费一区二区三区 | 97在线看福利| 亚洲国产成人精品一区二区三区| 一区二区在线观看视频| xxxxwww一片| 在线 亚洲欧美在线综合一区| 97人人做人人人难人人做| 亚洲性图自拍| 亚洲成人久久网| 久久中文字幕免费| 欧美激情在线观看视频免费| 91福利免费观看| 欧美日本一区| 免费影院在线观看一区| 国产精品xxx| 欧美巨乳美女视频| 无码精品人妻一区二区| 在线观看中文字幕不卡| 美女福利视频网| 国产成人av影院| 欧美精品色婷婷五月综合| 精品视频亚洲| 91在线观看免费观看| а√在线中文网新版地址在线| 亚洲另类xxxx| 国产农村老头老太视频| 午夜成人免费电影| 99国产精品免费| 成人性视频网站| 嫩草影院国产精品| 欧美激情第10页| 欧美一二三四五区| 日韩区欧美区| 国产精品盗摄久久久| 三级网站视频在在线播放| 亚洲深夜福利视频| 午夜精品久久久久久久99老熟妇| 欧美性xxxxx极品娇小| 国产三级aaa| 91在线高清观看| √天堂资源在线| 久久久久综合| 日韩精品在线中文字幕| 精品一区二区三区在线| 高清日韩一区| 99精品美女视频在线观看热舞 | 国产无遮挡又黄又爽又色| 中文字幕免费观看一区| 色综合久久五月| 精久久久久久久久久久| 春日野结衣av| 国产精品大片免费观看| 神马影院一区二区三区| 美女视频免费精品| 亚洲最大av网站| 成人激情视屏| 欧洲午夜精品久久久| 色呦呦在线资源| 综合网中文字幕| 免费成人av电影| 亚洲成人久久一区| 国产色视频在线| 欧美色手机在线观看| 中文字幕高清在线免费播放| 亚洲主播在线播放| 国产黄在线免费观看| 国产精品网友自拍| 亚洲精品国产一区黑色丝袜| av资源站一区| 无码国产精品一区二区免费式直播 | 黑人糟蹋人妻hd中文字幕| 欧美96在线丨欧| 色香蕉在线观看| 久久亚洲国产| 伊人久久青草| 久久在线视频免费观看| 天堂社区 天堂综合网 天堂资源最新版 | 国产亚洲精品自在久久| 亚洲国产视频二区| 91一区二区三区| 麻豆视频久久| 亚洲自拍偷拍网址| 日韩精品一区二区三区中文字幕| 成人精品aaaa网站| 警花av一区二区三区| 91精品在线一区| 精品国产亚洲日本| 91久久国产精品91久久性色| 成年永久一区二区三区免费视频| 国产精品美女主播| 日韩福利影视| 成人国产精品久久久久久亚洲| 日韩午夜电影免费看| 国产伦精品一区二区三区精品视频| 国产一区影院| 成人激情av在线| 欧美三级一区| 国产 高清 精品 在线 a| 国产精品色呦| 精品蜜桃传媒| 久久av资源| 午夜一区二区三视频在线观看| 日韩av自拍| 色爽爽爽爽爽爽爽爽| 国产精品久久| 免费无遮挡无码永久视频| 美女爽到呻吟久久久久| 在线观看高清免费视频| 麻豆成人久久精品二区三区小说| 午夜精品免费看| 国产成人精品三级| 影音先锋人妻啪啪av资源网站| 久久综合色婷婷| 四虎成人免费影院| 一区二区三区中文字幕在线观看| 国产无遮挡aaa片爽爽| 色综合久久综合网欧美综合网| 国产精品sm调教免费专区| 91精品在线麻豆| 特黄aaaaaaaaa真人毛片| 亚洲色图校园春色| 中文字幕在线播放网址| 777精品视频| 精品九九久久| 国产精品一区二区三区在线| 亚洲精品3区| 做爰高潮hd色即是空| 亚洲精品1234| 特级丰满少妇一级| 懂色av一区二区在线播放| 亚洲天堂视频一区| 日韩理论在线观看| 日本高清不卡码| 日韩一区二区三区视频在线 | 中文字幕乱码在线观看| 欧美mv日韩mv亚洲| jizz在线免费观看| 久久全球大尺度高清视频| 69堂免费精品视频在线播放| 亚洲va欧美va国产综合剧情| 亚洲第一论坛sis| 小泽玛利亚av在线| 日韩福利电影在线| 欧亚乱熟女一区二区在线| 国产精品九色蝌蚪自拍| 97免费在线观看视频| 欧美老女人第四色| 男女污污视频在线观看| 欧美第一淫aaasss性| 精品福利在线| 欧美日韩一区在线视频| 欧美激情 亚洲a∨综合| 色噜噜狠狠一区二区| 91网站在线播放| 久久精品国产亚洲av无码娇色| 欧美色视频在线观看| 麻豆影视在线| 97色在线观看| 999久久精品| 超碰成人在线免费观看| 日本麻豆一区二区三区视频| 亚洲熟女一区二区| 一区二区三区国产豹纹内裤在线| 亚洲天堂国产精品| 在线观看久久久久久| 性欧美freesex顶级少妇| 国产精品视频一区二区三区经| 91精品电影| 亚洲怡红院在线| 国产精品日日摸夜夜摸av| 久草视频一区二区| 日韩精品在线电影| 欧美男男tv网站在线播放| 国产一区二区三区高清视频| 国产精品magnet| 野花视频免费在线观看| 亚洲精品国产成人久久av盗摄| 亚洲天堂自拍偷拍| 在线播放国产一区中文字幕剧情欧美| 在线手机中文字幕| 免费精品视频一区二区三区| 亚洲精品影视| 朝桐光av一区二区三区| 亚洲高清免费观看 | 99视频在线精品| 国产一级二级毛片| 欧美不卡激情三级在线观看| 欧美xxxx少妇| 国产精品jizz视频| 亚洲黄色一区| 精品国产av色一区二区深夜久久| 亚洲图片欧美一区| 头脑特工队2在线播放| 欧美一区二区.| 久久综合影院| 成人午夜激情av| 国产精品高潮呻吟| 国产视频一区二区三区四区五区| 久久电影一区二区| 大陆精大陆国产国语精品| www.日本在线播放| 久久久亚洲高清| 做爰无遮挡三级| 久久精品成人一区二区三区 | 欧美www视频| а√在线中文在线新版| 欧美精品成人一区二区在线观看| 久热国产精品| 2014亚洲天堂| 欧美成人欧美edvon| 国产精品电影| 色综合视频二区偷拍在线| 免费不卡在线视频| 日韩一级片av| 精品视频中文字幕| 91麻豆精品成人一区二区| 精品一区二区久久久| 午夜精品一区二区三区视频| 亚洲第一av网| 电影在线观看一区二区| 久久视频免费在线| 久久伊99综合婷婷久久伊| 中文字幕 人妻熟女| 久久99久久久久久久噜噜| 妖精视频一区二区三区免费观看| 久久99爱视频| 亚洲图片欧美视频| 2019中文字幕在线视频| 97久久天天综合色天天综合色hd| 亚洲欧美日本国产专区一区| 手机免费观看av| 亚洲第一福利视频| 99精品国自产在线| 性欧美大战久久久久久久| 国产午夜亚洲精品羞羞网站| 99久久久国产精品无码网爆| 欧美有码在线视频| 综合久久一区| 日本一区二区视频在线播放| 精品免费日韩av| 日韩伦理一区二区| 欧美xxxxx在线视频| 一区二区三区色|