epoll IO多路復(fù)用模型實(shí)現(xiàn)機(jī)制

epoll的設(shè)計(jì)和實(shí)現(xiàn)與select完全不同。epoll通過在Linux內(nèi)核中申請一個簡易的文件系統(tǒng)
調(diào)用epoll_create()建立一個epoll對象(在epoll文件系統(tǒng)中為這個句柄對象分配資源)

調(diào)用epoll_ctl向epoll對象中添加這100萬個連接的套接字

調(diào)用epoll_wait收集發(fā)生的事件的連接

只需要在進(jìn)程啟動時建立一個epoll對象,然后在需要的時候向這個epoll對象中添加或者刪除連接。同時,epoll_wait的效率也非常高,因?yàn)檎{(diào)用epoll_wait時,并沒有一股腦的向操作系統(tǒng)復(fù)制這100萬個連接的句柄數(shù)據(jù),內(nèi)核也不需要去遍歷全部的連接。

1、阻塞 I/O 只能阻塞一個 I/O 操作,而 I/O 復(fù)用模型能夠阻塞多個 I/O 操作,所以才叫做多路復(fù)用
2、采用epoll模型時創(chuàng)建了一個共享的內(nèi)存空間,操作系統(tǒng)采用事件通知的方式,使一個進(jìn)程能同時等待多個文件描述符
3、這樣就可以同時監(jiān)聽多個網(wǎng)絡(luò)連接 IO, 相對于多進(jìn)程、多線程切換的開銷問題,IO 多路復(fù)用可以極大的提升系統(tǒng)效率

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容