在 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參數里面,代碼是這樣的:
接下來的代碼就是調用instance的方法(IMyServiceContract里面定義的)。
可是測試發現設置的timeout參數沒起作用,超時還是21秒。
后來網上搜了一下,的確這是個普遍的問題,看看 這個 和 這個 帖子,但可惜都沒有解決我的問題。網上都沒有好的辦法,無奈我只好自己搞定了。用.NET 4.0 TPL里面的 Task.Wait(timeSpan) 和cancel搞定。
使用Task.Wait和Cancel解決Remoting超時Timeout問題
先看看下面的代碼:
我想你一定看懂了,意思就是,線程池啟動一個線程,做一些事情(這里假設耗時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里面的話可能不工作,沒有效果,看下面的代碼:
原因是如果連接到"tcp:// 192.192.192.192 :8080/ServerObject"這個不存在的Remoting service地址,可能會在Activator.GetObject 或者 instance.dosomething()這一步出現connection failed的異常,提示遠程remoting服務器連接不上,然后就走到catch里面調用了 ChannelServices.UnregisterChannel 了嗎?沒有,還有retryCount,失敗重試,所以實際并沒有執行注銷channel。
正確的解決方法是在其他地方,或者過一會兒再調用 ChannelServices.UnregisterChannel 。或者在我上述的函數測試一個遠程地址是否可用TestRemotingServerAddress調用完成以后,如果是false,就調 ChannelServices.UnregisterChannel 。此外,如果endpoint地址改變了,需要調用 ChannelServices.UnregisterChannel ,否則會發生異常。
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

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