您好,登錄后才能下訂單哦!
這篇文章主要講解了“linux中的五種IO模型是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“linux中的五種IO模型是什么”吧!
對于一次IO操作,數據會先拷貝到內核空間中,然后再從內核空間拷貝到用戶空間中,所以一次read操作,會經歷兩個階段:
(1)等待數據準備
(2)數據從內核空間拷貝到用戶空間
基于以上兩個階段就產生了五種不同的IO模式。
從進程發起IO操作,一直等待上述兩個階段完成。
兩階段一起阻塞。
進程一直詢問IO準備好了沒有,準備好了再發起讀取操作,這時才把數據從內核空間拷貝到用戶空間。
第一階段不阻塞但要輪詢,第二階段阻塞。
多個連接使用同一個select去詢問IO準備好了沒有,如果有準備好了的,就返回有數據準備好了,然后對應的連接再發起讀取操作,把數據從內核空間拷貝到用戶空間。
兩階段分開阻塞。
進程發起讀取操作會立即返回,當數據準備好了會以通知的形式告訴進程,進程再發起讀取操作,把數據從內核空間拷貝到用戶空間。
第一階段不阻塞,第二階段阻塞。
進程發起讀取操作會立即返回,等到數據準備好且已經拷貝到用戶空間了再通知進程拿數據。
兩個階段都不阻塞。
各種IO模式同比如下:
同步非同步的區別在于調用操作系統的recvfrom()的時候是否阻塞,可見除了最后的異步IO其它都是同步IO。
select 有最大文件描述符的限制,只能監聽到有幾個文件描述符就緒了,得遍歷所有文件描述符獲取就緒的IO。
poll 沒有最大文件描述符的限制,與select一樣,只能監聽到有幾個文件描述符就緒了,得遍歷所有文件描述符獲取就緒的IO。
epoll 沒有最大文件描述符的限制,它通過回調的機制,一旦某個文件描述符就緒了,迅速激活這個文件描述符,當進程下一次調用epoll_wait()的時候便得到通知。
所以,在有大量空閑連接的時候,epoll的效率要高很多。
感謝各位的閱讀,以上就是“linux中的五種IO模型是什么”的內容了,經過本文的學習后,相信大家對linux中的五種IO模型是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。