• <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網(wǎng)絡(luò)模型總結(jié)

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

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

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

            評論

            # re: Epoll網(wǎng)絡(luò)模型總結(jié)[未登錄] 2012-01-17 11:22 冷鋒

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

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

            2020久久精品亚洲热综合一本| 久久国产色AV免费看| 国产精品久久久99| 婷婷久久久亚洲欧洲日产国码AV| 亚洲精品无码专区久久久| 久久综合综合久久97色| AAA级久久久精品无码区| 久久天天躁夜夜躁狠狠躁2022| 久久久久青草线蕉综合超碰| A级毛片无码久久精品免费| 伊人久久成人成综合网222| 亚洲伊人久久大香线蕉综合图片| 久久精品国产99久久无毒不卡| 久久久久国产亚洲AV麻豆| 久久亚洲精品中文字幕| 97久久精品人人做人人爽| 久久996热精品xxxx| 亚洲午夜无码久久久久小说| 久久人人爽人人爽人人片AV不 | 亚洲国产精品成人久久蜜臀| 久久97久久97精品免视看秋霞| 久久久久国产一区二区三区| 亚洲狠狠婷婷综合久久久久| 久久99精品国产99久久6男男| 亚洲人成网站999久久久综合| 久久久久亚洲av无码专区导航| 久久久久无码中| 99久久亚洲综合精品网站| 久久国产乱子伦免费精品| 一级a性色生活片久久无少妇一级婬片免费放 | 嫩草伊人久久精品少妇AV| 久久国产成人午夜AV影院| 久久综合九色综合久99| 国产亚洲精品自在久久| 久久免费精品一区二区| 久久精品国产99久久久| 少妇高潮惨叫久久久久久| 国产精品国色综合久久| 久久婷婷五月综合色高清| 久久久久一级精品亚洲国产成人综合AV区| 色综合久久久久网|