epoll的設(shè)計(jì)和實(shí)現(xiàn)與select完全不同铛只。epoll通過在Linux內(nèi)核中申請一個(gè)簡易的文件系統(tǒng)
調(diào)用epoll_create()建立一個(gè)epoll對象(在epoll文件系統(tǒng)中為這個(gè)句柄對象分配資源)
調(diào)用epoll_ctl向epoll對象中添加這100萬個(gè)連接的套接字
調(diào)用epoll_wait收集發(fā)生的事件的連接
只需要在進(jìn)程啟動時(shí)建立一個(gè)epoll對象育叁,然后在需要的時(shí)候向這個(gè)epoll對象中添加或者刪除連接。同時(shí)握侧,epoll_wait的效率也非常高,因?yàn)檎{(diào)用epoll_wait時(shí)里初,并沒有一股腦的向操作系統(tǒng)復(fù)制這100萬個(gè)連接的句柄數(shù)據(jù)惨好,內(nèi)核也不需要去遍歷全部的連接煌茴。
1、阻塞 I/O 只能阻塞一個(gè) I/O 操作日川,而 I/O 復(fù)用模型能夠阻塞多個(gè) I/O 操作蔓腐,所以才叫做多路復(fù)用
2、采用epoll模型時(shí)創(chuàng)建了一個(gè)共享的內(nèi)存空間龄句,操作系統(tǒng)采用事件通知的方式回论,使一個(gè)進(jìn)程能同時(shí)等待多個(gè)文件描述符
3、這樣就可以同時(shí)監(jiān)聽多個(gè)網(wǎng)絡(luò)連接 IO分歇, 相對于多進(jìn)程傀蓉、多線程切換的開銷問題,IO 多路復(fù)用可以極大的提升系統(tǒng)效率