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

            focus on linux, c/c++, lua

            Epoll網絡模型總結

            整個網絡模型分為兩個層次,一個是網絡消息層(Epoll), 一個是邏輯層。這兩層開兩個線程同時進行。當socket連接服務器成功之后,在epoll維護的事件隊列中,加入該socket,并標記其當前為已連接狀態,可以進行發送或是接受消息。下面針對Send和Recv兩個分別描述。
            首先epoll會在主循環中輪詢新建立的鏈接,如果有新的鏈接,則執行鏈接動作,(邏輯層在鏈接時,有時候也需要做一些事情,可提供接口回調)。
            1,Recv,接收網絡消息為被動動作。只能由epoll的主循環驅動。當epoll檢測到某個socket接收到新的數據時,connection把其中的數據取出來,放在本地緩存,并對其進行判斷,是否是一個完整的包,根據tcp的滑動窗口協議,socket的一次recv的數據可能并不是像邏輯層想象的那樣,一次就發一個完整的包,要對包進行判斷和處理。 如果在connection中,收到并判斷是一個完整的包。則把該包的數據,加入到邏輯層的數據隊列,讓邏輯層去處理。
            2,Send, Send不同與Recv,Send是主動事件,由邏輯層的某發送接口觸發,所以在connection中要提供一個循函數(Send)給邏輯層回調。首先把要發送的數據,放在本地緩存,讓后修改當前socket的狀態,告訴Epoll我有數據要發送,讓Epoll來回調我的發送接口。Epoll來回調的時候,有可能發現我有很多包要發,或是因為其他網絡原因,包積攢了很多,那么就要把這些包有順序的放在隊列中,一個一個的有序的發出去。如果一個包很大,一次發不完,怎么辦?那也只能通過本地的緩存調整,最終發送完。不過一般會規定最大的包長的。
            至于邏輯層的主循環,就很簡單了,因為它只要處理被動的接受包的邏輯,這個時候,不管邏輯層的分層多么的詳細,都無所謂了,思路已經很清晰了!

            寫完這篇文章,還有個道理就是鼓勵下自己:今天搞不懂的代碼,明天可以搞懂,明天不行,后天,總有一天搞懂的,相信自己最重要!

            posted on 2010-06-10 10:40 zuhd 閱讀(1367) 評論(1)  編輯 收藏 引用 所屬分類: server

            評論

            # re: Epoll網絡模型總結[未登錄] 2012-01-17 11:22 冷鋒

            我用的epoll ET模式,我的recv跟你一樣,但是Send的有點區別,我是在邏輯線程里面嘗試直接發送,先判斷下發送隊列是否為空,如果為空的話那么直接發送,當然這里可能遇到發不完的情況,因此要記錄下發送的位置,然后丟到發送隊列中,IO線程里面,在可寫事件到來時去檢查隊列并發送隊列的數據。

            PS:
            IO線程通知邏輯線程我是通過條件變量,有點好奇你在邏輯線程是怎么通知IO線程的,IO線程應該已經在epoll_wait了,你是弄了個管道什么的嗎?像memcached那樣的做法。  回復  更多評論   

            97久久天天综合色天天综合色hd| 亚洲国产精品无码久久青草| 亚洲国产精品一区二区久久hs| 亚洲国产成人久久一区WWW| 久久久一本精品99久久精品88| 久久香蕉超碰97国产精品| 99久久精品国产一区二区蜜芽| 国产精品乱码久久久久久软件 | 777米奇久久最新地址| 精品久久人人做人人爽综合| 狠狠精品久久久无码中文字幕| 久久亚洲欧美日本精品| 亚洲欧美日韩久久精品第一区| 99久久精品国产一区二区蜜芽| 久久AV高潮AV无码AV| 97精品伊人久久久大香线蕉| 狠狠色婷婷久久综合频道日韩 | 性色欲网站人妻丰满中文久久不卡| 国产精品久久久久影院色| 久久精品国产欧美日韩99热| 91精品国产高清久久久久久91| 777午夜精品久久av蜜臀 | 无码精品久久久天天影视| 午夜精品久久久久久久无码| 精品综合久久久久久97超人| 蜜臀av性久久久久蜜臀aⅴ| 伊人精品久久久久7777| 狠狠精品干练久久久无码中文字幕| 久久人人妻人人爽人人爽| 亚洲国产日韩欧美久久| 久久精品国产清自在天天线| 香蕉久久一区二区不卡无毒影院| 精品久久久噜噜噜久久久| 久久中文骚妇内射| 久久久亚洲欧洲日产国码aⅴ| 亚洲AV日韩精品久久久久| 久久精品国产99久久久古代| 亚洲AV无一区二区三区久久| 亚洲中文字幕久久精品无码喷水| 久久天天躁狠狠躁夜夜躁2014| 理论片午午伦夜理片久久|