這篇文章帶給大家的內容是關於對swoole的架構分析,有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。
結構圖如下:
swoole主要由Master進程(主進程)和Manager進程配合使用完成其功能。
是一個多執行緒的程式。其中有一組很重要的線程,稱為Reactor線程。它就是真正處理TCP連接,收發資料的線程。
管理worker/task進程。 worker/task進程都是由Manager進程Fork並管理的。
主線程(Master進程)在Accept新的連接後,會將這個連接分配給一個固定的Reactor線程,並由這個線程負責監聽此socket。在socket可讀時讀取數據,並進行協定解析,將請求投遞到Worker進程。
負責維護客戶端TCP
連線、處理網路IO
、處理協定、收發資料
完全是非同步非阻塞的模式
全部為C
程式碼,除Start
/Shudown
事件回調外,不執行任何PHP代碼
將TCP
客戶端發送的資料緩衝、拼接、分割成完整的一個請求數據套件
Reactor
以多執行緒的方式運行
類似與php- fpm進程。
接受由Reactor
執行緒投遞的請求資料包,並執行PHP
回呼函數處理資料
產生回應資料並發給Reactor
線程,由Reactor
線程傳送給TCP
客戶端
Worker以多進程的方式運行
Worker進程透過
swoole_server->task/taskwait方法投遞的任務
##處理任務,並將結果資料傳回(
##TaskWorker
以多進程的方式運行
關係
可以理解為
Reactor就是
nginx,
Worker就是
php-fpm。
Reactor
Worker進程中去處理(在回調函數中處理)。 Reactor和Worker
間透過UnixSocket
進行通訊。 事件處理流程 了解swoole事件處理流程,先了解兩種網路事件處理模式。 Reactor模式它要求主執行緒(I/O處理單元)只負責監聽檔案描述子上是否有事件發生,有的話就立即將該事件通知工作執行緒/進程(邏輯單元)。除此之外,主線程不做任何其他工作。讀寫數據,接受新的連接,以及處理客戶請求均在工作線程中完成。於是佇列的消費者執行緒處理請求對象,然後在epoll核心事件表中註冊socket上的寫入就緒事件。
主執行緒呼叫epoll_wait等待socket可寫。
當socket可寫入時,epoll_wait通知主執行緒。主執行緒往socket寫入請求結果。
#從圖可以看出,如果我們把Reactor執行緒和Work進程組合起來,看成工作線程的話,swoole使用的是reactor事件處理模式。
一個請求經歷的步驟如下:
1. 伺服器主執行緒等待客戶端連線。
2. Reactor執行緒處理接連socket,讀取socket上的請求資料(Receive),將請求封裝好後投遞給work程序。
3. Work流程就是邏輯單元,處理業務資料。
4. Work進程結果回傳給Reactor執行緒。
5. Reactor執行緒將結果寫回socket(Send)。
每個模組的工作請回顧上面的結構介紹。
相關推薦:
如何自訂一個Model? ThinkPHP3.2自訂基底類別Model的用法
#以上是swoole的架構分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!