• <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>

            Sheppard Y

            keep thinking keep coding.

            了解云風的skynet

            2016-07-11 日更新 
            此篇博客已經遷移到新博客,并做行文檢查和優化排版:
            http://blog.clawz.me/2014/01/16/14-cloudwu-skynet-research/



            (PS開始應用《暗時間》里提到的理論,將skynet用自己的話來總結并寫下來,這樣能充分思考并轉述為自己的記憶線索)


            一、skynet設計的理解

            (一)單個skynet節點

            (1)愿景

                充分利用多核。最初想法是多進程。像咱們nodejs里多核就只能是多進程了,因為每個nodejs進程是單線程的。

                多進程是遵循unix設計哲學,工具鏈形式,分拆進程的形式來分拆模塊,減少復雜度和耦合性,方便編程及維護。

                后來云風他們發現lua做為嵌入式腳本,寫邏輯時很好用的,反正如何都要用lua,而且lua提供了沙盒,這樣多進程可以變為單進程多個沙盒,這樣綜合了多進程和單進程多線程的優勢。多線程里共享資源,在同一進程地址空間,訪問更高效。


            (2)核心功能(門房?)

                很精簡,僅解決一個問題。

                skynet里不實現具體游戲邏輯,后者些放到一個一個動態庫里(so文件)。skynet將這些so注冊到自己里邊,每個so一個永不重復的id,類似于數據庫的autoincreament。看描述這個id是skynet自己運行時當次維護的,而不是模塊配置好終身的id。模塊的永久有效唯一標示為名字,skynet提供了名字服務,可以給每個模塊取一個易讀的名字。


            (3)核心不解決什么問題

                skynet主張所有服務在同一OS進程協作完成。核心里就沒管跨機通訊,單個服務的崩潰和重啟也沒管,云風表示這些應該由上層處理,他有責任暴露錯誤,而不是隱藏。

                這個設計的原因,游戲和操作系統不一樣,操作系統默認不信任任何進程,各進程崩潰什么的不應影響其他進程,所以某個進程掛了,他就安葬它,而其他進程美好的生活。單游戲是為玩家服務的,某個環節出錯都有可能造成玩家利益混亂,所以那里錯了就整個流程(服務器)掛掉吧。沒有必要讓出錯模塊被隔離開,而其他模塊卻繼續提供服務導出未預知行為。

                上邊說的東西應該上層考慮,使用lua的沙盒就能做策略隔離。


            (4)skynet運行時邏輯流

                skynet負責且只負責將一個數據包從一個服務發送到同一進程的另一個服務里。發送服務直接調發送API,skynet收到數據包后,調用接受者服務的注冊的callback,即發給了接受者服務。

                skynet保證在各模塊初始化時、每個獨立的callback調用時,都是相互線程安全的。這樣編寫服務的人就不需要考慮多線程的任何問題了,只需專心處理給他的一個個數據包。

                PS:天龍的場景lua有點像這里的單個服務。不知天龍的跨線程切場景情況在這里也可以給簡化為單線程?(回頭看源碼再研究這個問題)


            (5)消息調度

            TODO


            (6)gate和connection

            TODO


            (二)skynet集群

                集群里最多支持255個skynet節點,每個skynet節點有一個id,成為harbor id。這個id是集群層面指定,可以人為分配,也可以由一個中央服務器協調分配。

            (1)集群間通信

                skynet核心層紙負責在往外發消息時在source字段上加上自己的harbor id。而集群間的通信,是由單獨的harbor服務來做的。skynet將是往集群其他節點發的消息,就轉發到harbor內。harbor會跟集群內跟自己結識的skynet的harbor簡歷tcp鏈接。harbor把消息發給目標harbor。

                harbor間的通信為單向的tcp管道。

                master服務來同步全局的名字服務。每個skynet都會知道其他節點上裝配了哪些服務,好路由過去。


            (2)組播

                TODO

            posted on 2014-01-16 11:25 Sheppard Y 閱讀(8925) 評論(0)  編輯 收藏 引用 所屬分類: 設計架構開源

            <2013年10月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導航

            統計

            留言簿(1)

            隨筆分類(77)

            隨筆檔案(58)

            me

            基友

            同行

            業界前輩

            最新隨筆

            搜索

            積分與排名

            最新評論

            閱讀排行榜

            久久亚洲国产欧洲精品一| 一本一本久久A久久综合精品| 久久久中文字幕| 久久精品国产只有精品66 | 成人国内精品久久久久影院| 色噜噜狠狠先锋影音久久| 思思久久99热免费精品6| 亚洲精品tv久久久久久久久 | 精品国产综合区久久久久久| 国产亚洲精午夜久久久久久| 97香蕉久久夜色精品国产| 国产精品久久久久无码av| 亚洲精品无码久久毛片| 国产99精品久久| 伊人久久大香线蕉亚洲五月天| 精品久久久久久无码国产| 香蕉久久夜色精品升级完成| 久久精品国产清自在天天线| 久久精品视频免费| 久久婷婷国产综合精品| 亚洲国产婷婷香蕉久久久久久| 国产99久久久国产精免费| 77777亚洲午夜久久多人| 伊人久久大香线蕉综合5g| 精品久久国产一区二区三区香蕉| 狼狼综合久久久久综合网| 午夜视频久久久久一区 | 99久久国产综合精品五月天喷水 | 婷婷综合久久中文字幕蜜桃三电影| 国产毛片久久久久久国产毛片| 精品国产一区二区三区久久久狼| 亚洲AV伊人久久青青草原| 久久综合给合综合久久| 国产精品日韩欧美久久综合| 精品久久一区二区三区| 久久99国产乱子伦精品免费| 亚洲AV无码久久精品成人 | 香蕉久久一区二区不卡无毒影院| 久久亚洲欧美国产精品| 天天爽天天狠久久久综合麻豆| 国内精品伊人久久久影院|