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

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

 更新時間:2016年09月22日 09:43:38   作者:dudu  
這篇文章主要介紹了解決 .NET Core 中 GetHostAddressesAsync 引起的 EnyimMemcached 死鎖問題的相關資料,需要的朋友可以參考下

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

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

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

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

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

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

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

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

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

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

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

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

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 ,只是返回參數(shù)是 Task 類型,那在同步方法中調(diào)用完全沒問題,只要在訪問 .Result 之前調(diào)用一下 .Wait() 方法就行了,于是改為下面的代碼:

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

死鎖問題立馬解決!

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

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

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

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

相關文章

  • .net core高吞吐遠程方法如何調(diào)用組件XRPC詳解

    .net core高吞吐遠程方法如何調(diào)用組件XRPC詳解

    這篇文章主要給大家介紹了關于.net core高吞吐遠程方法如何調(diào)用組件XRPC的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用.net core具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-05-05
  • DotNet OnPreRender(EventArgs e) 事件常用的方法

    DotNet OnPreRender(EventArgs e) 事件常用的方法

    DotNet OnPreRender(EventArgs e) 事件常用的方法,需要的朋友可以參考下。
    2011-07-07
  • Asp.net實現(xiàn)選擇性的保留DataTable中的列

    Asp.net實現(xiàn)選擇性的保留DataTable中的列

    選擇性的保留DataTable中的列(移除列/保留列不移除/移除不需要的列),很多新手朋友們都想實現(xiàn)這樣的功能,本文總結了一些可行方法,感興趣的朋友可以了解下哦
    2013-01-01
  • 學習制作MVC4分頁控件(上)

    學習制作MVC4分頁控件(上)

    這篇文章主要教大家學習制作MVC4分頁控件,自己動手編寫HtmlHelper-Pager分頁控件,感興趣的小伙伴們可以參考一下
    2016-08-08
  • .NET6中使用CuteEditor詳解

    .NET6中使用CuteEditor詳解

    本文詳細講解了.NET6中使用CuteEditor的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-12-12
  • 批量刪除記錄時如何實現(xiàn)全選方法總結

    批量刪除記錄時如何實現(xiàn)全選方法總結

    批量刪除記錄時如何實現(xiàn)全選方法總結...
    2007-04-04
  • ASP.NET自定義Web服務器控件之Button控件

    ASP.NET自定義Web服務器控件之Button控件

    這篇文章主要介紹了ASP.NET自定義Web服務器控件之Button控件,詳細講述了Button控件的實現(xiàn)代碼、前臺頁面的調(diào)用以及對應的事件響應代碼,具有很好的參考借鑒價值,需要的朋友可以參考下
    2014-11-11
  • 詳解如何在ASP.NET Core中應用Entity Framework

    詳解如何在ASP.NET Core中應用Entity Framework

    本篇文章主要介紹了如何在ASP.NET Core中應用Entity Framework,具有一定的參考價值,有興趣的可以一起了解一下。
    2016-12-12
  • asp.net窗體操作總結

    asp.net窗體操作總結

    這些代碼全部寫在和頁面分離的代碼頁中(codebehind),如果要嵌入到*.aspx頁面,可能會出現(xiàn)問題.
    2008-11-11
  • gojs一些實用的高級用法

    gojs一些實用的高級用法

    gojs是一個非常強大的可視化關系的js庫。本文介紹的是在使用gojs制作圖的過程中,你可能會碰到的問題的一些解決方案。對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-01-01

最新評論