精品欧美一区二区三区在线观看 _久久久久国色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ù)棧公眾號

97人妻一区二区精品免费视频 | h片在线观看视频免费免费| 激情五月婷婷综合| 97视频在线播放| 1024手机在线观看你懂的| 欧美a在线观看| 色综合久久综合网97色综合| 女同性恋一区二区| 日韩a级作爱片一二三区免费观看| 日韩国产高清在线| 欧美激情亚洲激情| 国产99在线 | 亚洲| 中文字幕一区二区三区四区久久| 欧美性色19p| 日韩成人午夜影院| 国产亚洲依依| 成人免费电影视频| 国产一区二中文字幕在线看| 尤物视频在线观看国产| 91成人国产| 一区二区亚洲精品国产| 色综合久久五月| av日韩一区| 欧美亚洲动漫另类| 欧美激情 国产精品| 黄色免费在线看| 欧美国产日本韩| 狠狠色伊人亚洲综合网站色| 国产欧美一级片| 日本不卡的三区四区五区| 久久青草福利网站| 强乱中文字幕av一区乱码| 欧美亚洲精品在线| 亚洲欧美日韩成人| 午夜剧场免费看| 亚洲性视频在线| 91精品国产综合久久久久久久| 黄色高清无遮挡| 亚洲天堂av影院| 亚洲大片在线观看| 日本大片免费看| 26uuu亚洲电影在线观看| 国产精品系列在线| 天堂精品一区二区三区| 国产永久免费高清在线观看视频| 91热门视频在线观看| 国产一区不卡在线观看| 丰满人妻一区二区三区四区53| 国产一区在线不卡| 成人国产精品久久久久久亚洲| 精品国产www| 免费观看日韩av| 国产欧美一区二区三区久久人妖| 无码人妻一区二区三区线| 免费欧美日韩| 国产成人极品视频| 免费黄色一级大片| 日本va欧美va瓶| 国产精品日韩在线播放| 中文字幕一区二区三区人妻四季| 日韩电影在线免费看| 国产精品久久久久久久app | 日本aⅴ免费视频一区二区三区| 国产成人精品免高潮费视频| 最新国产中文字幕| 久久国产精品区| 亚洲aⅴ男人的天堂在线观看| 国产成人精品av在线观| 成人永久看片免费视频天堂| 精品日本一区二区三区在线观看 | 亚洲视频欧洲视频| 国产探花视频在线播放| 亚洲国产一区二区三区在线播放| 久久综合伊人77777| 久久免费小视频| 亚洲一区二区三区高清| 国产精品www| 国产又黄又爽视频| 成人听书哪个软件好| 久久精品国产精品国产精品污| 天天摸天天干天天操| 中文字幕欧美区| 女同性恋一区二区| 午夜欧美激情| 欧美美女网站色| 国产av一区二区三区传媒| 伊人久久大香线蕉综合网站| 中文字幕亚洲一区在线观看| 中国一级片在线观看| 欧美人与禽猛交乱配视频| 日本久久精品视频| 91国内精品久久久| 99视频一区二区| 亚洲精品一卡二卡三卡四卡| 丁香花电影在线观看完整版 | 亚洲精品怡红院| 日韩精品中文字幕一区二区| 日韩精品免费视频| 国产极品美女在线| 国产精品视区| 91成人在线看| lutube成人福利在线观看| 亚洲五月六月丁香激情| 亚洲最大综合网| jizz国产精品| 日日噜噜噜夜夜爽亚洲精品 | 久久99精品久久久久子伦| 91在线播放网站| 欧美日韩激情视频| 亚洲AV无码久久精品国产一区| 香蕉久久精品| 欧美激情第一页xxx| 亚洲性生活大片| 91蜜桃婷婷狠狠久久综合9色| 男同互操gay射视频在线看| 成人直播视频| 亚洲第一视频在线观看| 中文字幕无码日韩专区免费| 久久久xxx| 国产视频精品网| 四虎影视成人| 8v天堂国产在线一区二区| 鲁丝一区二区三区| 一本色道久久综合亚洲精品不| 亚洲最大成人免费视频| a√资源在线| 91福利精品第一导航| 午夜视频在线观看国产| 国产精品99一区二区三区| 国产成人亚洲综合91精品| 天堂在线视频网站| 夜夜精品视频一区二区| 国产毛片久久久久久| 国产大片一区| 国产日韩欧美在线视频观看| 第一页在线观看| 日本福利一区二区| 在线观看日本中文字幕| 亚洲一卡久久| 欧美一级日本a级v片| 小黄鸭精品aⅴ导航网站入口| 亚洲精品国产拍免费91在线| 日韩黄色精品视频| 成人高清视频免费观看| 日韩xxxx视频| 精品日产乱码久久久久久仙踪林| 久久久亚洲国产| 女人18毛片一区二区三区| 一区二区欧美在线观看| 中文字幕人妻熟女在线| 亚洲经典三级| 女女同性女同一区二区三区91| 久草在线中文最新视频| 亚洲久久久久久久久久久| 中文字字幕在线中文| 久久久久久麻豆| 美女少妇一区二区| 香港欧美日韩三级黄色一级电影网站| 成人a级免费视频| 羞羞的网站在线观看| 亚洲成av人影院在线观看| 日本污视频在线观看| 99久久国产综合精品色伊| 成年人黄色片视频| 久久国产精品亚洲人一区二区三区| 国产日韩视频在线观看| 岛国成人毛片| 亚洲国产古装精品网站| 免费av网站在线| 中文子幕无线码一区tr| 涩多多在线观看| 极品尤物久久久av免费看| 成人三级在线| 成人影院网站| 久久av在线看| 视频国产在线观看| 一本大道久久a久久综合婷婷| 国产成人在线网址| 懂色av一区二区夜夜嗨| 777精品久无码人妻蜜桃| 凹凸成人精品亚洲精品密奴| 91丨九色丨国产在线| 女海盗2成人h版中文字幕| 中文字幕在线观看亚洲| 国产wwwwwww| 色婷婷综合在线| 顶臀精品视频www| 91片黄在线观看| 热久久久久久久久| 亚洲伦伦在线| 91香蕉视频网址| 欧亚精品一区| 91在线网站视频| 日韩电影免费观看高清完整版| 不卡av电影院| 黄色在线视频观看网站| 精品日韩欧美在线| 国产精品传媒在线观看| 亚洲国产视频一区| 91动漫免费网站| 97se亚洲国产综合在线| 中文字幕一区久久| 久久aⅴ乱码一区二区三区| 日本三级中文字幕在线观看| 久久综合欧美| 国产精品亚洲一区| 91麻豆精品| 国产成人亚洲精品| 国产理论在线| 欧美成人精品xxx| bbbbbbbbbbb在线视频| 亚洲精品国产免费| 精品人妻一区二区三区四区不卡 | 黄色精品一区二区| 成人自拍小视频| 国产日产欧美一区二区视频| 中文在线观看免费视频| 国产乱码字幕精品高清av| www.xxx亚洲| 国产精品丝袜xxxxxxx| 日韩在线观看a| 亚洲激情五月| 一本色道久久综合亚洲二区三区| 国产欧美日韩免费观看| 久久精品日产第一区二区三区乱码 | 欧美成人精品一区二区男人看| 日韩精品视频免费专区在线播放 | 暴力调教一区二区三区| wwwxxxx在线观看| 国产尤物一区二区| 黄色aaaaaa| 久草中文综合在线| 777一区二区| 看国产成人h片视频| 性刺激的欧美三级视频| 奇米777欧美一区二区| 女人另类性混交zo| 久久久久久一区二区| 久久久免费视频网站| 一本色道精品久久一区二区三区 | 成人国产二区| 77777亚洲午夜久久多人| yellow字幕网在线| 97超级碰在线看视频免费在线看| 2021中文字幕在线| 97香蕉超级碰碰久久免费的优势| 成人bbav| 欧美最猛性xxxxx免费| 欧美天堂视频| 国产精品久在线观看| 啪啪av大全导航福利综合导航| 国产精品亚洲片夜色在线| 国产精品伊人| 亚洲一区亚洲二区亚洲三区| 中文字幕一区二区三区中文字幕 | 97超碰人人看人人| 99精品国产高清一区二区麻豆| 9a蜜桃久久久久久免费| 国产精品毛片久久久| 久久久久se| 精品久久久久久久| 一个色的综合| 欧美午夜a级限制福利片| 国产欧美日韩小视频| 丝袜诱惑制服诱惑色一区在线观看| 欧洲熟妇精品视频| 久久精品国产77777蜜臀| 亚洲欧美一区二区三区不卡| 福利一区二区在线| 熟女少妇一区二区三区| 欧美国产1区2区| 2018天天弄| 福利视频第一区| 亚洲无码精品在线播放| 精品国产91久久久久久久妲己| 无码国产精品96久久久久| 伊人久久五月天| 精品美女在线观看视频在线观看| 久久久久久久久久久成人| 在线天堂资源| 91在线视频导航| 亚洲春色h网| 国产精品88久久久久久妇女 | 男女视频在线看| 国产乱人伦偷精品视频不卡| 9.1成人看片| 日韩理论片网站| 久久久久久久久久久久久av| 欧美日韩高清一区二区| 日本xxxxwww| 色妞欧美日韩在线| 国产v日韩v欧美v| 成人精品一区二区三区电影免费| 欧美大胆a级| 黄色免费高清视频| 久久综合影视| 亚洲女则毛耸耸bbw| 国产精品美女一区二区在线观看| 亚洲激情视频一区| 欧美丰满高潮xxxx喷水动漫| 日本在线视频1区| 欧美久久久精品| 主播大秀视频在线观看一区二区| 成人在线免费观看一区| 水蜜桃精品av一区二区| 99爱视频在线| 丁香婷婷综合五月| 999精品在线视频| 色婷婷综合久久久中文字幕| 黑人乱码一区二区三区av| 日韩在线观看网站| 午夜精品久久久久久久久久蜜桃| 国产日韩一区二区| 在线电影一区二区| 粉色视频免费看| 久久久高清一区二区三区| 黄色小说在线观看视频| 欧美一区午夜精品| 日本中文字幕在线播放| 国产精品69久久| 欧美在线导航| 精品欧美一区免费观看α√| 高清视频一区二区| 卡通动漫亚洲综合| 在线成人小视频| 日本中文字幕在线播放| 国产精品老女人视频| 免费欧美一区| 黄色片一级视频| 91麻豆文化传媒在线观看| 日本系列第一页| 精品国产免费视频| 免费不卡av| 成人免费视频网站| 国内精品99| 欧美激情一区二区三区p站| 一区二区三区在线观看动漫| 国产成人a人亚洲精品无码| 操人视频在线观看欧美| 免费一级欧美片在线观看网站| 91制片厂免费观看| 国产精品资源在线看| 一区二区在线观看免费视频| 欧美一级二级在线观看| 欧美人与牲禽动交com | 精品理论电影| 麻豆一区二区三区视频| 欧美高清在线一区二区| 91成品人影院| 久久99亚洲热视| 国产伦精品一区二区三区免费优势| 僵尸世界大战2 在线播放| 99这里只有精品| 不卡av电影在线| 中文字幕日韩在线观看| 91成人福利社区| 日韩在线观看a| 26uuu国产一区二区三区| 亚洲毛片一区二区三区| 主播福利视频一区| 99热这里有精品| 亚洲熟妇无码一区二区三区| 久久综合av免费| 中文字幕网址在线| 欧美成人精品影院| 日韩欧美四区| 三级a在线观看| 亚洲精品国产精品乱码不99 | 日韩在线免费观看视频| 日韩在线网址| 哪个网站能看毛片| 中文字幕五月欧美| 日本黄色一区二区三区| 国产精品va在线播放| 欧美日本一区二区视频在线观看 | 国产精欧美一区二区三区白种人| 亚洲尤物在线视频观看| 日本福利午夜视频在线| 成人h猎奇视频网站| 亚洲高清网站| 美国一级黄色录像| 精品久久久久久久久久久院品网 | 1卡2卡3卡精品视频| 色在线视频观看| 久久九九有精品国产23| 成人直播在线观看| 99草草国产熟女视频在线| 中文字幕视频一区二区三区久| 黄色小视频免费观看| 国产精品久久久久久久美男| 欧美精品网站| 亚洲精品成人无码| 日韩一区二区三区高清免费看看| 日韩欧美精品一区二区三区| 欧美日韩在线免费观看视频| 91一区二区在线观看| av无码精品一区二区三区宅噜噜| 2019精品视频| 欧美 日韩 国产一区二区在线视频 | 精品国产亚洲一区二区三区在线|