站長資訊網
        最全最豐富的資訊網站

        linux中poll和select有什么區別

        linux中poll和select的區別是:select單個進程所能打開的最大連接數由“FD_SETSIZE”宏定義,其大小是32個整數的大小,而poll因為采用鏈表存儲,所以沒有最大連接數的限制。

        linux中poll和select有什么區別

        本教程操作環境:linux7.3系統、Dell G3電腦。

        linux中poll和select有什么區別

        每個進程使用的select有最大連接數限制,只能有FD_SETSIZE個,而poll沒有這樣的限制(采用鏈表存儲);

        epoll跟select都能提供多路I/O復用的解決方案。在現在的Linux內核里有都能夠支持,其中epoll是Linux所特有,而select則應該是POSIX所規定,一般操作系統均有實現

        select:

        select本質上是通過設置或者檢查存放fd標志位的數據結構來進行下一步處理。這樣所帶來的缺點是:

        1、 單個進程可監視的fd數量被限制,即能監聽端口的大小有限。

        一般來說這個數目和系統內存關系很大,具體數目可以cat /proc/sys/fs/file-max察看。32位機默認是1024個。64位機默認是2048.

        2、 對socket進行掃描時是線性掃描,即采用輪詢的方法,效率較低:

        當套接字比較多的時候,每次select()都要通過遍歷FD_SETSIZE個Socket來完成調度,不管哪個Socket是活躍的,都遍歷一遍。這會浪費很多CPU時間。如果能給套接字注冊某個回調函數,當他們活躍時,自動完成相關操作,那就避免了輪詢,這正是epoll與kqueue做的。

        3、需要維護一個用來存放大量fd的數據結構,這樣會使得用戶空間和內核空間在傳遞該結構時復制開銷大

        poll:

        poll本質上和select沒有區別,它將用戶傳入的數組拷貝到內核空間,然后查詢每個fd對應的設備狀態,如果設備就緒則在設備等待隊列中加入一項并繼續遍歷,如果遍歷完所有fd后沒有發現就緒設備,則掛起當前進程,直到設備就緒或者主動超時,被喚醒后它又要再次遍歷fd。這個過程經歷了多次無謂的遍歷。

        它沒有最大連接數的限制,原因是它是基于鏈表來存儲的,但是同樣有一個缺點:

        1、大量的fd的數組被整體復制于用戶態和內核地址空間之間,而不管這樣的復制是不是有意義。

        2、poll還有一個特點是“水平觸發”,如果報告了fd后,沒有被處理,那么下次poll時會再次報告該fd。

        epoll:

        epoll有EPOLLLT和EPOLLET兩種觸發模式,LT是默認的模式,ET是“高速”模式。LT模式下,只要這個fd還有數據可讀,每次 epoll_wait都會返回它的事件,提醒用戶程序去操作,而在ET(邊緣觸發)模式中,它只會提示一次,直到下次再有數據流入之前都不會再提示了,無 論fd中是否還有數據可讀。所以在ET模式下,read一個fd的時候一定要把它的buffer讀光,也就是說一直讀到read的返回值小于請求值,或者 遇到EAGAIN錯誤。還有一個特點是,epoll使用“事件”的就緒通知方式,通過epoll_ctl注冊fd,一旦該fd就緒,內核就會采用類似callback的回調機制來激活該fd,epoll_wait便可以收到通知。

        epoll為什么要有EPOLLET觸發模式?

        如果采用EPOLLLT模式的話,系統中一旦有大量你不需要讀寫的就緒文件描述符,它們每次調用epoll_wait都會返回,這樣會大大降低處理程序檢索自己關心的就緒文件描述符的效率.。而采用EPOLLET這種邊沿觸發模式的話,當被監控的文件描述符上有可讀寫事件發生時,epoll_wait()會通知處理程序去讀寫。如果這次沒有把數據全部讀寫完(如讀寫緩沖區太小),那么下次調用epoll_wait()時,它不會通知你,也就是它只會通知你一次,直到該文件描述符上出現第二次可讀寫事件才會通知你!!!這種模式比水平觸發效率高,系統不會充斥大量你不關心的就緒文件描述符

        epoll的優點:

        1、沒有最大并發連接的限制,能打開的FD的上限遠大于1024(1G的內存上能監聽約10萬個端口);

        2、效率提升,不是輪詢的方式,不會隨著FD數目的增加效率下降。只有活躍可用的FD才會調用callback函數;

        即Epoll最大的優點就在于它只管你“活躍”的連接,而跟連接總數無關,因此在實際的網絡環境中,Epoll的效率就會遠遠高于select和poll。

        3、 內存拷貝,利用mmap()文件映射內存加速與內核空間的消息傳遞;即epoll使用mmap減少復制開銷。

        select、poll、epoll 區別總結:

        1、支持一個進程所能打開的最大連接數

        select

        單個進程所能打開的最大連接數有FD_SETSIZE宏定義,其大小是32個整數的大小(在32位的機器上,大小就是3232,同理64位機器上FD_SETSIZE為3264),當然我們可以對進行修改,然后重新編譯內核,但是性能可能會受到影響,這需要進一步的測試。

        poll

        poll本質上和select沒有區別,但是它沒有最大連接數的限制,原因是它是基于鏈表來存儲的

        epoll

        雖然連接數有上限,但是很大,1G內存的機器上可以打開10萬左右的連接,2G內存的機器可以打開20萬左右的連接

        2、FD劇增后帶來的IO效率問題

        select

        因為每次調用時都會對連接進行線性遍歷,所以隨著FD的增加會造成遍歷速度慢的“線性下降性能問題”。

        poll

        同上

        epoll

        因為epoll內核中實現是根據每個fd上的callback函數來實現的,只有活躍的socket才會主動調用callback,所以在活躍socket較少的情況下,使用epoll沒有前面兩者的線性下降的性能問題,但是所有socket都很活躍的情況下,可能會有性能問題。

        3、 消息傳遞方式

        select

        內核需要將消息傳遞到用戶空間,都需要內核拷貝動作

        poll

        同上

        epoll

        epoll通過內核和用戶空間共享一塊內存來實現的。

        總結:

        綜上,在選擇select,poll,epoll時要根據具體的使用場合以及這三種方式的自身特點。

        1、表面上看epoll的性能最好,但是在連接數少并且連接都十分活躍的情況下,select和poll的性能可能比epoll好,畢竟epoll的通知機制需要很多函數回調。

        2、select低效是因為每次它都需要輪詢。但低效也是相對的,視情況而定,也可通過良好的設計改善

        推薦學習:Linux視頻教程

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 久久精品国产亚洲AV电影| 精品国产污污免费网站| 久久精品国产亚洲综合色| 国产成人精品高清在线观看93| 亚洲精品无码永久在线观看你懂的 | 色综合久久综精品| 久久国产精品久久国产精品| 亚洲精品第一国产综合精品99| 少妇精品久久久一区二区三区 | 日韩精品一区二区三区色欲AV| 精品一区二区三区免费视频 | 精品国产乱码久久久久久郑州公司| 国产成人精品福利网站在线| 久久精品国产福利国产秒| 日韩精品久久无码中文字幕| 日韩精品www| 国产精品日本一区二区不卡视频| 8x福利精品第一导航| 亚洲精品国产av成拍色拍| 久久久久久国产精品免费免费| 亚洲精品无码午夜福利中文字幕| 国产精品无码永久免费888 | 99精品国产成人一区二区| 久久精品国产色蜜蜜麻豆| 99精品视频在线观看免费| 精品亚洲aⅴ在线观看| 亚洲午夜国产精品无码老牛影视| 91麻豆国产福利精品| 日韩人妻无码精品久久久不卡 | 国产精品美女一区二区视频 | 日本一区二区三区精品中文字幕| 国产成人精品日本亚洲11 | 国产精品伊人久久伊人电影| www夜片内射视频日韩精品成人| 精品国产三级a乌鸦在线观看| 亚洲高清国产拍精品26U| 日韩精品成人亚洲专区| 精品三级在线观看| 99re6在线精品免费观看| 99久久婷婷免费国产综合精品| 国产精品成人观看视频国产|