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)效率