日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

DCOM的心跳

系統 2133 0

保持 DCOM 的心跳

?

文檔版本

版本

創建時間

創建人

備注

1.0.0114.1

2003-1-14

鄭昀

第一稿

?

?

?

?

編寫目的:

??? 本文檔將說明 DCOM 的心跳給編程上的影響

概述

我們的程序員前不久遇到過這樣的一個奇怪的現象:

服務器端創建出一個 ServerA 的實例,好幾個分布式的客戶端持有這個實例的引用,類似于 ConnectionPoint 的方式。客戶端負責向服務器端的實例發送電話撥入、按鍵、掛機等消息,服務器端負責處理這些消息。但是在生產環境中,每隔一段時間,服務器端調用持有的 客戶端 實例引用時,得到一個 COM 錯誤 0x80010108 ,意思是說被調用的對象已與其客戶端斷開連接。這時客戶端卻可以調用服務器端的實例,這時候的網絡通信質量也很好。實在是看不出來會是什么原因導致這種調用模式周期性出錯。程序員報告這個時間大約是 7 分鐘。

COM+的心跳

排除了代碼錯誤的可能性后,聯想到 COM+ 的一個特性:保持心跳。 COM+ 為了實現 JIT( 即時激活 ) ,必須每隔一段時間讓 COM+ 組件的實例和調用方之間保持一個心跳,告訴調用方,我還活著。以前沒有想過它為什么要定期發送一次消息,通知對方自己健在呢?也許這是一種規則,如果不這么做的話,一定會有大麻煩。

那么是 DCOM 協議的制約了?

我們從新聞組中得到了一個模糊的說明:

After 6 minutes of non usage, the server considers the client disconnected
and drops the connection. This is a fixed timeout for DCOM that cannot be
changed.

Okay ,看樣子我們的方向是正確的。確實存在一個約定的時間間隔: 6 分鐘。我們試圖描述我們得到的第一個概念: 6 分鐘內,服務器端沒有得到來自于客戶端的消息,就默認客戶端已經消失,于是斷開連接。所以我們這之后的再次調用,就會得到 0x80010108 COM 錯誤。

更多信息

Question:

我的 Server 如何判斷 Client 是否在運行中?

Background:

DCOM 設計時就預先要考慮能處理任何形式的 Server Client 或者 Network 崩潰的組合。所以 DCOM 決定在 Client Server 之間保持一個背景“ ping ”。如果 Client 的連接丟失, NT 將在 6 分鐘之內檢測到。這時,服務器故意模擬 Client 的正常斷開情形,將 Client Server 請求的所有接口的引用計數統統釋放。

Resolution:

正因為如此,編寫 Server 的程序員不必要太過于擔心 Client 的意外崩潰。 NT 將會從根本上保證 Client 正常斷開并釋放所有引用的接口。

?

6分鐘是如何計算出來的呢?

當一個 Connection 被請求建立之后, DCOM 將在三次不成功的 ping 之后,認定本次連接超時。由于這些 ping 每隔 2 分鐘發送一次,所以 6 分鐘就是這么計算出來的。

總結:

u ????? Pinging 是一種檢測客戶端是否異常終止的著名手段

u ????? 一般在服務器端的設計中,每一個輸出的對象都有一個 pingPeriodTime 參數,和一個 numPingsToTimeout 參數

u ????? 如果 pingPeriod 時間過去,而并未接收到來自于 Client ping ,所有對接口的遠程引用計數,將被認為失效,從而可以被垃圾回收器收回。

前面說的0x80010108問題解決辦法就是每隔半分鐘就給服務器發送一個無害的消息,保證connection不被斷掉。

?

本文檔所包含的信息代表了在發布之日, ZhengYun 對所討論問題的當前看法, Zhengyun 不保證所給信息在發布之日以后的準確性。

本文檔僅供參考。對本文檔中的信息, Zhengyun 不做任何明示或默示的保證。

Written by zhengyun@tomosoft.com



Trackback: http://tb.blog.csdn.net/TrackBack.aspx?PostId=12707


DCOM的心跳


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

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

【本文對您有幫助就好】

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

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 措勤县| 台南市| 舟曲县| 凤庆县| 南康市| 晋宁县| 民勤县| 砚山县| 绥中县| 襄垣县| 措美县| 铜梁县| 高邮市| 汽车| 重庆市| 项城市| 长泰县| 曲麻莱县| 扶沟县| 奎屯市| 梨树县| 会东县| 通州区| 东光县| 伊川县| 清镇市| 吉隆县| 博乐市| 读书| 乌海市| 广宗县| 乌兰察布市| 牡丹江市| 井冈山市| 如东县| 鹿泉市| 漳浦县| 云林县| 黑水县| 锡林郭勒盟| 浮梁县|