国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > epoll和select和poll的區(qū)別?

epoll和select和poll的區(qū)別?

來源:千鋒教育
發(fā)布人:xqq
時間: 2023-10-11 15:05:09 1697007909

一、epoll和select和poll的區(qū)別

三者對比

select:調用開銷大(需要復制集合);集合大小有限制;需要遍歷整個集合找到就緒的描述符poll:poll 采用數(shù)組的方式存儲文件描述符,沒有最大存儲數(shù)量的限制,其他方面和 select 沒有區(qū)別epoll:調用開銷小(不需要復制);集合大小無限制;采用回調機制,不需要遍歷整個集合

select、poll?都是在用戶態(tài)維護文件描述符集合,因此每次需要將完整集合傳給內核;epoll?由操作系統(tǒng)在內核中維護文件描述符集合,因此只需要在創(chuàng)建的時候傳入文件描述符。

此外?select?只支持水平觸發(fā),epoll?支持邊緣觸發(fā)。

適用場景

當連接數(shù)較多并且有很多的不活躍連接時,epoll 的效率比其它兩者高很多。當連接數(shù)較少并且都十分活躍的情況下,由于 epoll 需要很多回調,因此性能可能低于其它兩者。

延伸閱讀:

二、Redis 的線程模型是什么

Redis是一個單線程的工作模型,使用 I/O 多路復用來處理客戶端的多個連接。為什么 Redis 選擇單線程也能效率這么高?

I/O 設備(如磁盤、網(wǎng)絡)等速度遠遠慢于 CPU,因此引入了多線程技術。當一個線程發(fā)起 I/O 請求時,先將它掛起,切換到別的線程;當 I/O 設備就緒時,再切換回該線程。總之,多線程技術是為了充分利用 CPU 的計算資源,適用于下層存儲慢速的場景。

而 redis 是純內存操作,讀寫速度非常快。所有的操作都會在內存中完成,不涉及任何 I/O 操作,因此多線程頻繁的上下文切換反而是一種負優(yōu)化。Redis 選擇基于非阻塞 I/O 的?I/O 多路復用機制,在單線程里并發(fā)處理客戶端的多個連接,減少多線程帶來的系統(tǒng)開銷,同時也有更好的可維護性,方便開發(fā)和調試。

不過 redis 在最新的幾個版本中也引入了多線程,目的是:

異步處理刪除操作。當刪除超大鍵值對的時候,單線程內同步地刪除可能會阻塞待處理的任務應對網(wǎng)絡 I/O 的場景,網(wǎng)絡 I/O 是慢速 I/O。redis6 吞吐量提高了 1 倍
聲明:本站稿件版權均屬千鋒教育所有,未經(jīng)許可不得擅自轉載。
10年以上業(yè)內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT