您好,登錄后才能下訂單哦!
小編給大家分享一下PHP7內核剖析之I/O模型有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
1.同步:我客戶端(C端調用者)一個功能,該功能沒有結束前,我死等結果。
2.異步:我(c端調用者)調用一個功能,不知道該功能結果,該功能有結果后通知我,即回調通知
3.阻塞:就是調用我(s端被調用者,函數),我(s端被調用者,函數)沒有完全接受完數據或者沒有得到結果之前,我不會返回。
4.非阻塞:就是調用我(s端被調用者,函數),我(s端被調用者,函數)立即返回,得出結果后通知調用者
五種I/O模型
(1) 阻塞I/O (Blocking I/O)
當用戶進程進行系統調用時,內核就開始了I/O的第一個階段,準備數據到緩沖區中,當數據都準備完成后,則將數據從內核緩沖區中拷貝到用戶進程的內存中,這時用戶進程才解除block的狀態重新運行。
(2) 非阻塞I/O (Non-Blocking I/O)
用戶進程只有在第二個階段被阻塞了,而第一個階段沒有阻塞,但是在第一個階段中,用戶進程不需要盲等,不停的去輪詢內核,看數據是否準備好了,因此該模型是比較消耗CPU的。
(3) I/O復用(I/O Multiplexing)
I/O執行的兩個階段都是用戶進程都是阻塞的,但是兩個階段是獨立的,在一次完整的I/O操作中,該用戶進程是發起了兩次系統調用。和阻塞I/O不同的是第一段可以等待多個描述符就緒
(4) 信號驅動的I/O (Signal Driven I/O)
只有在I/O執行的第二階段阻塞了用戶進程,而在第一階段是沒有阻塞的。該模型在I/O執行的第一階段,當數據準備完成之后,會主動的通知用戶進程數據已經準備完成,即對用戶進程做一個回調。該通知分為兩種,一為水平觸發,即如果用戶進程不響應則會一直發送通知,二為邊緣觸發,即只通知一次。
(5) 異步I/O (Asynchrnous I/O)
當用戶進程發起系統調用后,立刻就可以開始去做其它的事情,然后直到I/O執行的兩個階段都完成之后,內核會給用戶進程發送通知,告訴用戶進程操作已經完成了。
I/O多路復用技術
select
(1).select()的機制中提供一fd_set的數據結構,每一個元素都能與一打開的文件句柄(不管是Socket句柄,還是其他 文件或命名管道或設備句柄)建立聯系,建立聯系的工作由程序員完成, 當調用select()時,由內核根據IO狀態修改fd_set的內容,由此來通知執行了select()的進程哪一Socket或文件可讀或可寫。主要用于Socket通信當中。
(2).程序執行select后,如果沒有數據輸入,程序會一直等待(阻塞時),直到有數據為止,也就是程序中無需循環和sleep。
(3).每次調用select,都需要把fd_set集合從用戶態拷貝到內核態,這個開銷在fd_set很多時會很大
(4).同時每次調用select都需要在內核遍歷傳遞進來的所有fd_set,這個開銷在fd_set很多時也很大
(5).select支持的文件描述符數量太小了,默認是1024
poll
(1).poll的實現和select非常相似,只是描述fd_set集合的方式不同,poll使用pollfd鏈表結構而不是select的fd_set結構,其他的都差不多。
(2).監視描述符個數無上限;
epoll/kqueue
(1).監視描述符個數無上限;
(2).效率提升,不是輪詢的方式,不會隨著fd數目的增加效率下降。只有活躍可用的fd才會調用callback函數;即epoll/kqueue最大的優點就在于它只管你“活躍”的連接,而跟連接總數無關,因此在實際的網絡環境中,epoll/kqueue的效率就會遠遠高于select和poll。
(3).內存拷貝,利用mmap()文件映射內存加速與內核空間的消息傳遞;
以上是PHP7內核剖析之I/O模型有哪些的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。