亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

使用Task.Wait和Cancel解決Remoting超時Timeout

系統 2161 0

Remoting 客戶端用 TcpChannel 鏈接服務端的時候,如果地址不存在會嘗試連接到超時Timeout大概21秒左右,例如連接到"tcp:// 192.192.192.192 :8080/ServerObject"這個不存在的Remoting service地址。如何才能縮短這個 Remoting 超時Timeout的時間呢?根據 MSDN Channel Properties 說明: 默認的timeout設置 是infinite(無限),默認失敗嘗試次數/retryCount是一次。所以很自然,設置 Remoting 客戶端用 TcpChannel 鏈接服務端的連接超時timeout在timeout參數里面,代碼是這樣的:

使用Task.Wait和Cancel解決Remoting超時Timeout問題_第1張圖片

接下來的代碼就是調用instance的方法(IMyServiceContract里面定義的)。

可是測試發現設置的timeout參數沒起作用,超時還是21秒。

后來網上搜了一下,的確這是個普遍的問題,看看 這個 這個 帖子,但可惜都沒有解決我的問題。網上都沒有好的辦法,無奈我只好自己搞定了。用.NET 4.0 TPL里面的 Task.Wait(timeSpan) 和cancel搞定。

使用Task.Wait和Cancel解決Remoting超時Timeout問題

先看看下面的代碼:

使用Task.Wait和Cancel解決Remoting超時Timeout問題_第2張圖片

我想你一定看懂了,意思就是,線程池啟動一個線程,做一些事情(這里假設耗時4秒),但必須在超時時間timeout時間內(這里是3秒)內完成,timeout時間到了就取消該線程任務,并返回false。如果操作在3秒內完成了,那么久返回true。很簡單吧。

:這里用了 CancelationTokenSource.Cancel ()來取消線程任務,并且結合TPL里面的 Task.Wait(timeSpan) ,這樣實現timeout時間到了就取消該線程任務。請參考MSDN: Task Cancelation How to: Cancel a Task and Its Children . 細節:如果僅僅調用bool Wait(TimeSpan timeout),時間到了并不會停止任務執行,而是等待任務執行完成,看所用時間如果超過timespan就返回false,否則返回true。)

這個方法就是用來測試一個遠程地址是否可用,比如連接到"tcp:// 192.192.192.192 :8080/ServerObject"這個不存在的Remoting service地址,如果能在timeout時間內(例如3秒內)返回,那么測試成功。超過就是失敗的服務端地址。可以在上面do some task的地方放置你的耗時操作,例如 Activator.GetObject 或者 instance.dosomething() - 一定要用try-catch括起來哦。

需要注意ChannelServices.UnRegisterChannel

有一點需要注意 ChannelServices.UnregisterChannel ,如果放在try-catch的那個block里面的話可能不工作,沒有效果,看下面的代碼:

使用Task.Wait和Cancel解決Remoting超時Timeout問題_第3張圖片

原因是如果連接到"tcp:// 192.192.192.192 :8080/ServerObject"這個不存在的Remoting service地址,可能會在Activator.GetObject 或者 instance.dosomething()這一步出現connection failed的異常,提示遠程remoting服務器連接不上,然后就走到catch里面調用了 ChannelServices.UnregisterChannel 了嗎?沒有,還有retryCount,失敗重試,所以實際并沒有執行注銷channel。

正確的解決方法是在其他地方,或者過一會兒再調用 ChannelServices.UnregisterChannel ?;蛘咴谖疑鲜龅暮瘮禍y試一個遠程地址是否可用TestRemotingServerAddress調用完成以后,如果是false,就調 ChannelServices.UnregisterChannel 。此外,如果endpoint地址改變了,需要調用 ChannelServices.UnregisterChannel ,否則會發生異常。

使用Task.Wait和Cancel解決Remoting超時Timeout問題


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。?!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 深夜福利国产 | 四虎精品福利视频精品 | 久久欧洲视频 | 欧美刺激午夜性久久久久久久 | 久草免费公开视频 | 99国产超薄丝袜足j在线播放 | 日韩第1页 | 欧美一级视频在线 | 在线观看男女爱视频网站 | 全免费a级毛片免费看不卡 全免费a级毛片免费看视频免 | 中文字幕专区高清在线观看 | 亚洲视频免费在线 | 精品在线播放视频 | 四虎国产精品一区二区 | 午夜久久免费视频 | 四虎影院成人在线观看 | 五月婷花 | 日韩一级黄色影片 | 精品新一区二区三区四区 | 久草视频福利在线观看 | 免费一级片 | www.亚洲精品.com | 欧美午夜片 | 伊人久久五月天 | 亚洲综合一区二区精品久久 | 亚洲综合视频网 | 国产资源在线播放 | 国产中文字幕在线观看 | 九九福利| 午夜一区 | 国产香港特级一级毛片 | 免费观看a毛片一区二区不卡 | 国产人成精品免费视频 | 亚洲欧洲国产成人综合一本 | 亚洲精品国产美女在线观看 | 九色国产在视频线精品视频 | 国产精品亚洲片在线观看麻豆 | 一区二区中文字幕在线观看 | 日韩一区视频在线 | 99精品久久99久久久久 | 欧美三级一区二区 |