Swoole
是 php 的一個擴展,可是他又不是普通的擴展,其最明顯的特色就是:一但運行後就會接管PHP的控制權,進入事件循環。 當某種IO事件發生時, Swoole
會回調開發者設置的指定PHP函數。php
也就是說 SwooleServer
更像是一個用 C
語言封裝好的一個 Tcp/Udp
支持 多線程
, EventLoop
,事件驅動
,異步
等功能的框架。開發者不須要關心底層的各類實現,直接的在業務層面進行開發便可。程序員
不少 php 程序員沒有使用過其餘語言開發Server,也不太瞭解除了php-fpm之外運行模式的php程序,初次使用Swoole時老是會有各類摸不到頭腦的事情。其實IO咱們常常提起如: 磁盤IO
,網絡IO
在這裏Swoole所指的IO事件其實是指 網絡IO
事件。swoole
在平常生活中你留下了一個郵箱,當有人給你發送郵件的時候,你就會收到郵件提醒;而對於你而言,你並不關心郵件是如何送達的,你只關心你有沒有收到郵件,當你收到郵件以後會根據郵件的內容和發送人去作各類各樣的處理。在這個比喻中,Swoole就承擔了底層網絡事件的監聽及各類底層事件處理,當收到郵件(請求)時,會觸發收件(接收)提醒,而後將控制權轉交給你(預先註冊的事件回調函數),來進行後續的處理。網絡
<?php // new 一個SwoolerServer對象 並指定監聽端口 和運行模式 以及Socket類型 // 此時的一切一切 都是開發者進行配置的時間,沒有任何其餘事情發生 $server = new Swoole\Server('0.0.0.0', 9501, SWOOLE_PROCESS, SWOOLE_SOCK_TCP); // 設置運行參數, 就像你平時作的那樣,給$server 對象配置相關的參數 $server->set([ 'worker_num' => 4, // 工做進程數量 'daemonize' => true, // 是否以守護進程模式運行 'backlog' => 128, // Listen隊列長度 ]); // 註冊事件回調函數 // 這裏指 當底層Tcp新鏈接進入事件時 交給Tcp 類的 onConnect 靜態方法處理 $server->on('Connect', [Tcp::class, 'onConnect']); // 這裏指 當收到數據時 交給Tcp 類的 onReceive 靜態方法處理 $server->on('Receive', [Tcp::class, 'onReceive']); // 這裏指 當Tcp客戶端鏈接關閉時 交給Tcp 類的 onClose 靜態方法處理 $server->on('Close', [Tcp::class, 'onClose']);
在上面的示例當中,實際上Swoole還還沒有啓動,可是咱們已經預先配置了許多必要的配置條件。鑑於有的新人還尚不瞭解什麼叫作 回調函數
,在這裏我簡單的講解一下:多線程
所謂的
回調函數(CallBack)
就比如是張開了夾子的捕鼠器,咱們設定當有老鼠踩到捕鼠器的時候,他會關閉夾子而後捉住老鼠,咱們放置捕鼠器的時候,捕鼠器並無真的抓老鼠。這個設定就是回調,他不馬上執行,會在遇到觸發條件(事件)時執行,在上面的示例當中咱們放置了3個捕鼠器(回調函數),咱們只須要知道他會在特定老鼠(事件)踩到的時候(發生的時候)去執行咱們指望的功能就好。框架
// 啓動Swole Server 將由 Swoole 接管php運行 $server->start();
至此Swoole 徹底的接管了php的運行,而且監聽相應端口並當發生事件時去執行開發者自定義的事件回調。異步
事實上Swoole 在啓動的時候作了很是多的事情:函數
Swoole 運行流程圖: php-fpm
Swoole 進程關係圖: oop
上圖中咱們能夠了解,Swoole 會建立一個 Manager
進程專門 管理 Work
和 Task
進程。 而 Work
進程則直接經過 Unix Socket
和 Master
進程通信。