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

            那誰(shuí)的技術(shù)博客

            感興趣領(lǐng)域:高性能服務(wù)器編程,存儲(chǔ),算法,Linux內(nèi)核
            隨筆 - 210, 文章 - 0, 評(píng)論 - 1183, 引用 - 0
            數(shù)據(jù)加載中……

            epoll為什么這么快

            epoll是多路復(fù)用IO(I/O Multiplexing)中的一種方式,但是僅用于linux2.6以上內(nèi)核,在開(kāi)始討論這個(gè)問(wèn)題之前,先來(lái)解釋一下為什么需要多路復(fù)用IO.

            以一個(gè)生活中的例子來(lái)解釋.

            假設(shè)你在大學(xué)中讀書,要等待一個(gè)朋友來(lái)訪,而這個(gè)朋友只知道你在A號(hào)樓,但是不知道你具體住在哪里,于是你們約好了在A號(hào)樓門口見(jiàn)面.

            如果你使用的阻塞IO模型來(lái)處理這個(gè)問(wèn)題,那么你就只能一直守候在A號(hào)樓門口等待朋友的到來(lái),在這段時(shí)間里你不能做別的事情,不難知道,這種方式的效率是低下的.

            現(xiàn)在時(shí)代變化了,開(kāi)始使用多路復(fù)用IO模型來(lái)處理這個(gè)問(wèn)題.你告訴你的朋友來(lái)了A號(hào)樓找樓管大媽,讓她告訴你該怎么走.這里的樓管大媽扮演的就是多路復(fù)用IO的角色.

            進(jìn)一步解釋select和epoll模型的差異.

            select版大媽做的是如下的事情:比如同學(xué)甲的朋友來(lái)了,select版大媽比較笨,她帶著朋友挨個(gè)房間進(jìn)行查詢誰(shuí)是同學(xué)甲,你等的朋友來(lái)了,于是在實(shí)際的代碼中,select版大媽做的是以下的事情:

            int n = select(&readset,NULL,NULL,100);

            for (int i = 0; n > 0++i)
            {
               
            if (FD_ISSET(fdarray[i], &readset))
               {
                  do_something(fdarray[i]);
                  --n;
               }
            }

            epoll版大媽就比較先進(jìn)了,她記下了同學(xué)甲的信息,比如說(shuō)他的房間號(hào),那么等同學(xué)甲的朋友到來(lái)時(shí),只需要告訴該朋友同學(xué)甲在哪個(gè)房間即可,不用自己親自帶著人滿大樓的找人了.于是epoll版大媽做的事情可以用如下的代碼表示:
            n=epoll_wait(epfd,events,20,500);
               
            for(i=0;i<n;++i)
            {
                do_something(events[n]);
            }

            在epoll中,關(guān)鍵的數(shù)據(jù)結(jié)構(gòu)epoll_event定義如下:
            typedef union epoll_data {
                            
            void *ptr;
                            
            int fd;
                            __uint32_t u32;
                            __uint64_t u64;
                    } epoll_data_t;

                    
            struct epoll_event {
                            __uint32_t events;      
            /* Epoll events */
                            epoll_data_t data;      
            /* User data variable */
                    }; 
            可以看到,epoll_data是一個(gè)union結(jié)構(gòu)體,它就是epoll版大媽用于保存同學(xué)信息的結(jié)構(gòu)體,它可以保存很多類型的信息:fd,指針,等等.有了這個(gè)結(jié)構(gòu)體,epoll大媽可以不用吹灰之力就可以定位到同學(xué)甲.

            別小看了這些效率的提高,在一個(gè)大規(guī)模并發(fā)的服務(wù)器中,輪詢IO是最耗時(shí)間的操作之一.再回到那個(gè)例子中,如果每到來(lái)一個(gè)朋友樓管大媽都要全樓的查詢同學(xué),那么處理的效率必然就低下了,過(guò)不久樓底就有不少的人了.

            對(duì)比最早給出的阻塞IO的處理模型, 可以看到采用了多路復(fù)用IO之后, 程序可以自由的進(jìn)行自己除了IO操作之外的工作, 只有到IO狀態(tài)發(fā)生變化的時(shí)候由多路復(fù)用IO進(jìn)行通知, 然后再采取相應(yīng)的操作, 而不用一直阻塞等待IO狀態(tài)發(fā)生變化了.

            從上面的分析也可以看出,epoll比select的提高實(shí)際上是一個(gè)用空間換時(shí)間思想的具體應(yīng)用.



            posted on 2008-10-12 22:35 那誰(shuí) 閱讀(20331) 評(píng)論(15)  編輯 收藏 引用 所屬分類: 網(wǎng)絡(luò)編程服務(wù)器設(shè)計(jì)Linux/Unix

            評(píng)論

            # re: epoll為什么這么快[未登錄](méi)  回復(fù)  更多評(píng)論   

            不錯(cuò)不錯(cuò),大媽的比喻甚是形象
            2008-10-14 13:18 | frank

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            這個(gè)例子甚好!
            弄不清楚epoll和select的區(qū)別來(lái)著。
            2008-10-22 22:18 | ronliu

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            niu
            2008-12-12 11:00 | kou

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            比喻很形象,如果能再加上一些測(cè)試數(shù)據(jù)就好了
            2009-07-01 17:10 | liang

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            好文章!Squid、Memcahed 以及 Nginx 就是采用epoll多路復(fù)用模型的。學(xué)習(xí)了。
            2009-08-24 23:24 | wanwan

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            可以看到,epoll_data是一個(gè)union結(jié)構(gòu)體,它就是epoll版大媽用于保存同學(xué)信息的結(jié)構(gòu)體,它可以保存很多類型的信息:fd,指針,等等.有了這個(gè)結(jié)構(gòu)體,epoll大媽可以不用吹灰之力就可以定位到同學(xué)甲.
            這里解釋不太對(duì),這個(gè)結(jié)構(gòu)體是用戶用來(lái)判斷是哪個(gè)SOCKET的特征。不是快速找到的原因。
            2009-10-07 10:34 | LXJ

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            說(shuō)實(shí)話,從樓主列舉的代碼,沒(méi)看到select 和epoll 的區(qū)別在哪里?
            2010-03-02 14:55 | guest

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            挺好的。

            不過(guò)關(guān)于回調(diào)那 不是很清楚
            2010-08-26 11:08 | 欣萌

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            比喻的真是好!
            2010-10-01 12:39 | khejing

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            orz.......
            (樓主一定這么干過(guò)吧)
            2010-11-16 21:00 | zgx

            # re: epoll為什么這么快[未登錄](méi)  回復(fù)  更多評(píng)論   


            樓主的分析是錯(cuò)誤的。
            epoll的高效是在內(nèi)核實(shí)現(xiàn)的高效,并不是應(yīng)用程序的實(shí)現(xiàn)的高效。
            看看內(nèi)核代碼就搞清楚了。
            2011-05-23 18:57 | kk

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            不錯(cuò),比喻很好
            2011-05-24 09:59 | www

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            擺脫,你這種文章充滿了錯(cuò)誤,擺脫不要誤導(dǎo)別人
            2012-08-12 15:06 | 顯然是錯(cuò)的

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            @guest
            確實(shí)沒(méi)看出區(qū)別,,,不是把挨個(gè)循環(huán)做到底層了么。。。。還是要循環(huán)吧
            2013-08-22 18:50 | kbl

            # re: epoll為什么這么快  回復(fù)  更多評(píng)論   

            @LXJ
            確實(shí)是,這很容易導(dǎo)致誤導(dǎo)
            2015-03-24 13:55 | 不知
            亚洲AV伊人久久青青草原| 国产亚洲精久久久久久无码77777| 97精品久久天干天天天按摩| 国产精品成人99久久久久91gav| 久久久久国产成人精品亚洲午夜| 久久亚洲熟女cc98cm| 狠狠色丁香婷婷综合久久来来去| 久久久久久久精品妇女99| 亚洲成人精品久久| 亚洲AV无一区二区三区久久| 狠狠久久综合| 国产精品一久久香蕉国产线看| 亚洲精品tv久久久久| 久久综合久久久| 色综合久久中文字幕无码| 色综合久久中文字幕综合网| 欧美日韩中文字幕久久伊人| 久久婷婷五月综合97色一本一本| 亚洲国产综合久久天堂 | 亚洲日本va午夜中文字幕久久| 久久久久亚洲av无码专区喷水 | 亚洲国产成人精品91久久久| 久久国产乱子精品免费女| 亚洲精品无码久久久影院相关影片| 久久精品国产72国产精福利| 狠狠色丁香婷综合久久| 精品久久久久久亚洲精品 | 青草久久久国产线免观| 精品久久久久久99人妻| A级毛片无码久久精品免费| 蜜桃麻豆www久久| 国产成人精品久久一区二区三区av | 99久久亚洲综合精品网站| 欧美777精品久久久久网| 国产精品成人精品久久久| 国产精品无码久久四虎| 久久精品无码一区二区三区免费| 久久黄视频| 欧美日韩精品久久免费| 亚洲乱码精品久久久久..| 久久91亚洲人成电影网站|