激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - 解決 .NET Core 中 GetHostAddressesAsync 引起的 EnyimMemcached 死鎖問題

解決 .NET Core 中 GetHostAddressesAsync 引起的 EnyimMemcached 死鎖問題

2020-03-25 14:41dudu ASP.NET教程

這篇文章主要介紹了解決 .NET Core 中 GetHostAddressesAsync 引起的 EnyimMemcached 死鎖問題的相關資料,需要的朋友可以參考下

在我們將站點從 ASP.NET + Windows 遷移至 ASP.NET Core + Linux 的過程中,目前遇到的最大障礙就是 —— 沒有可用的支持 .NET Core 的 memcached 客戶端。

我們一直用的是 EnyimMemcached ,在沒有其它選擇的情況下,我們自己嘗試著將 EnyimMemcached 遷移至 .NET Core。。。基于 .NET Core 修改好了代碼,在開發環境下測試通過,在 Linux 服務器上自己訪問很正常(沒有并發訪問量),但是只要接入一定的訪問量就會發生死鎖(deadlock),瀏覽器請求卡死。

這個問題困擾了我們很長時間,昨天才定位到是發生在將 memcached 服務器名稱解析為 IP 地址的時候。

var addresses = System.Net.Dns.GetHostAddressesAsync(host).Result;

這是我們在將 EnyimMemcached 遷移至 .NET Core 時修改過的代碼,之前調用的是同步方法:

var addresses = System.Net.Dns.GetHostEntry(host);

由于在 .NET Core Framework 的 System.Net.Dns 中沒有同步方法,只有異步方法,所以我們只能這樣調用異步方法。

看到上面的代碼,你也許會詫異:怎么用 .Result ,為什么不用 await ?不死鎖才怪呢。。。

你的詫異非常正確。我們也深知 .Result 的危害,在平時的代碼中堅決不用。但當時在修改 EnyimMemcached 的代碼時,由于這個方法是在 MemcachedClient 的構造函數中調用的,沒法改為 await 調用,被迫用了 .Result ,然后又把這個地方的修改給忘了。。。昨天才剛剛發現,立馬意識到罪魁禍首非常有可能就是這里的 .Result ,于是以此為突破口,想盡一切辦法實現在同步方法中調用異步辦法,并且在博問中尋求支援 —— 在同步方法中調用異步方法時如何避免死鎖問題 。

結果,用盡一切能想到與能找到的同步方法調用異步方法的方法,都沒能解決死鎖問題。如果實在找不到解決方法,我們準備采用最后一招也是最丑陋的一招 —— 不用 Dns.GetHostAddressesAsync() ,用 ProcessStartInfo 調用命令行命令解析 IP ,比如在 Linux 上用 getent hosts 主機名 。

在準備放棄之前,今天又想了想還有哪些可能帶來線索的地方漏掉了呢?突然想到有個重要地方竟然忘了,還沒看 Dns.GetHostAddressesAsync() 的源代碼實現。雖然不報太大希望,不就是個異步方法嗎,但還是要看一下。

于是從 github 上簽出 corefx 的源代碼,打開 Dns.GetHostAddressesAsync() 源代碼一看,感覺有點怪怪的,怎么用了 Task.Factory.FromAsync() ?

?
1
2
3
4
5
6
7
8
9
public static Task<IPAddress[]> GetHostAddressesAsync(string hostNameOrAddress)
{
  NameResolutionPal.EnsureSocketsAreInitialized();
  return Task<IPAddress[]>.Factory.FromAsync(
    (arg, requestCallback, stateObject) => BeginGetHostAddresses(arg, requestCallback, stateObject),
    asyncResult => EndGetHostAddresses(asyncResult),
    hostNameOrAddress,
    null);
}

開始沒反應過來,只是把這段代碼貼到博問的補充問題中,在貼完后突然反應過來了,咦,怎么沒有 async 關鍵字?方法名最后是 Async,我們一直以為是 async 方法,而且絲毫沒有懷疑過。。。

沒有 async ,只是返回參數是 Task 類型,那在同步方法中調用完全沒問題,只要在訪問 .Result 之前調用一下 .Wait() 方法就行了,于是改為下面的代碼:

?
1
2
3
Task<IPAddress[]> task = System.Net.Dns.GetHostAddressesAsync(host);
task.Wait();
var addresses = task.Result;

死鎖問題立馬解決!

方法名以 Async 結尾,卻不是 async 方法,當時的感想就是 —— 你的眼睛背叛你的心。如果不是我自己的誤解(只要以 Async 結尾,就應該是 async 方法),那就是一種流氓行為,就如 HttpClient 的流氓 —— 實現了 IDispose 接口,卻沒真正 Dispose 。

不管怎么樣,這個影響我們遷移至 .NET Core 的最大障礙終于消除了,值得慶祝!

支持 .NET Core 的 EnyimMemcached 的代碼還需要一些修改與完善,等修改好了,我們會把源代碼與 NuGet 包都發布出來。

通過此文希望能幫助到你解決這種問題,謝謝大家對本站的支持!

原文鏈接:http://www.cnblogs.com/dudu/p/5892778.html

延伸 · 閱讀

精彩推薦
Weibo Article 1 Weibo Article 2 Weibo Article 3 Weibo Article 4 Weibo Article 5 Weibo Article 6 Weibo Article 7 Weibo Article 8 Weibo Article 9 Weibo Article 10 Weibo Article 11 Weibo Article 12 Weibo Article 13 Weibo Article 14 Weibo Article 15 Weibo Article 16 Weibo Article 17 Weibo Article 18 Weibo Article 19 Weibo Article 20 Weibo Article 21 Weibo Article 22 Weibo Article 23 Weibo Article 24 Weibo Article 25
主站蜘蛛池模板: 亚洲天堂成人在线 | 国产免费小视频在线观看 | 国产在线播放91 | 国产99久久久国产精品 | 国产色视频免费 | 久久精品国产清自在天天线 | 黄色的视频免费观看 | 国产69精品久久99不卡免费版 | 九九热精品在线视频 | 久草视频免费 | 久久久久北条麻妃免费看 | 爱操影院 | 午夜激情视频网站 | 久久91久久久久麻豆精品 | 日本欧美一区 | 羞羞网站在线看 | 毛片在线视频免费观看 | 国产精品久久久久久久久久尿 | 欧洲黄色一级视频 | 亚洲成人午夜精品 | 成人午夜看片 | 国内精品视频饥渴少妇在线播放 | 法国极品成人h版 | 欧美粗暴analvideos | 国产精品久久久久久久午夜片 | 国产免费观看一区二区三区 | 久久久久成人精品亚洲国产 | 亚洲综合一区二区三区 | 男人久久天堂 | 日本在线不卡一区二区三区 | 免费a视频在线观看 | 操操操日日日干干干 | xxxx69hd一hd | 免费观看一区二区三区视频 | 成人毛片免费视频 | 夜添久久精品亚洲国产精品 | 欧美精品网址 | 日本欧美一区二区三区在线播 | 久热久操 | 成年人在线免费 | 日产精品久久久一区二区福利 |