• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            我自閑庭信步,悠然自得,不亦樂乎.

                                                   ------ Keep life simple
            GMail/GTalk/MSN:huyi.zg@gmail.com

             

            TIM中網絡模型變更

            一直都隱隱約約的感覺TIM的網絡模型還是有點問題,但卻總說不出具體問題來。時不時就會想起這個事,今天在車上,終于恍然大悟。
            也許是受wildfire和jabberd2的影響太深了(特別是wildfire),TIM中網絡和業務處理的聯系過于緊密,從套接口讀到數據流后,馬上就進入XML的PullParser分析階段,雖然之后有刻意的分離網絡操作和業務邏輯,但并不徹底。
            有時候業務處理還是能夠感覺到網絡的存在,我覺得這是個不良的設計。
            讓我耿耿于懷的,是Reactor的單線程特性。或許在某些情況下這是它的優勢,但運用不當,就會成劣勢。現在的TIM把業務邏輯和網絡IO都擠進了Reactor所控制的線程中,只要存在一點點的阻塞,吞吐率將大打折扣。
            wildfire敢把網絡和業務綁得那么緊,是因為它采用的per-request,per-thread的模型,網絡IO引起的阻塞不會影響到其他request處理。我也沒有wildfire那么大的膽子采用per-request,per-thread,上下文切換的消耗不說,畢竟線程的數量也是有限制的,我很懷疑到底能承受多少連接數,如果沒有記錯,Linux沒有重編譯內核,一個進程內最多是1024個線程,Windows能多些,好像是65535,數據可能不準確,但也說明了線程資源是有限的。同時,WFMOReactor在Windows下每個線程內可同時監視的句柄數(62個),也似乎太少了,這點也讓我煩惱。
            仔細推敲后,我認為還是把網絡和業務完全脫離比較好一點,用至少一個線程專門操作套接口,突破WaitForMultipleObjects的句柄數限制,再用另外一個線程來完成業務。在業務線程上使用管道過濾器模式來一步一步的處理數據。當Reactor線程接收到數據后,放進MessageBlock里面,用Task框架來處理。
            這種模型確實解決了原先的諸多毛病,但如果在這個時候改網絡模型,對整個項目是個不小的沖擊,極有可能導致在計劃的時間內不能完成項目。猶豫了一下,為了保證品質,最終還是在SubVersion上創建了新的試驗分支。
            module.jpg

            posted on 2006-03-27 22:54 HuYi 閱讀(491) 評論(0)  編輯 收藏 引用 所屬分類: Server

            導航

            統計

            常用鏈接

            留言簿(12)

            隨筆分類

            相冊

            收藏夾

            友情鏈接

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            評論排行榜

            久久婷婷色综合一区二区| 久久久久久亚洲精品成人| 国内精品免费久久影院| 久久综合视频网站| 伊人久久大香线蕉av一区| 国内精品久久久久伊人av| 免费一级做a爰片久久毛片潮 | 久久精品亚洲精品国产色婷| 国产精品99久久99久久久| 久久亚洲中文字幕精品一区四| 精产国品久久一二三产区区别| 99久久综合狠狠综合久久止| 日韩中文久久| 久久久青草青青亚洲国产免观| 亚洲精品无码久久毛片| 情人伊人久久综合亚洲| 午夜欧美精品久久久久久久| 久久性精品| 久久午夜电影网| 久久综合九色综合网站| 色青青草原桃花久久综合| 精品久久久久久无码国产| 色婷婷综合久久久中文字幕| 久久久噜噜噜久久中文字幕色伊伊| 国内精品久久国产大陆| 久久久噜噜噜www成人网| 日韩中文久久| 久久人人爽人人爽人人片AV麻豆| 久久青青草原综合伊人| 999久久久无码国产精品| 蜜臀久久99精品久久久久久小说| 久久人人爽人人爽人人av东京热| 久久久91人妻无码精品蜜桃HD | 日本强好片久久久久久AAA| 亚洲精品tv久久久久| 久久久久99精品成人片牛牛影视| 久久97久久97精品免视看| 久久精品女人天堂AV麻| 亚洲婷婷国产精品电影人久久| 日日狠狠久久偷偷色综合96蜜桃| 中文字幕无码久久精品青草|