在 Swoole 官網的自我介紹是「面向生產環境的 PHP 非同步網路通訊引擎」,首先 Swoole 它是一個網路應用的開發工具,它支援 Http、TCP、UDP、WebSocket。
Swoole 和我們傳統的 PHP 開發差別是有的,需要理解的概念也是有的。使用目前一些基於 Swoole 的框架開發的話,從開發習慣上和傳統的TP、LV 框架相差不多。
那為什麼要使用 Swoole?
我認為有以下幾點:
常駐記憶體,避免重複載入帶來的效能損耗,提升海量效能
協程非同步,提高對 I/O 密集型場景並行處理能力(如:微信開發、支付、登入等)
方便地開發 Http、WebSocket、TCP、UDP 等應用,可以與硬體通訊
PHP 高效能微服務架構成為現實
常駐記憶體
目前傳統 PHP框架,在處理每個請求之前,都要做一遍載入框架檔案、設定的操作。這可能已經成為效能問題的一大原因,而使用 Swoole 則沒有這個問題,一次載入多次使用。
協程
如下圖所示,這是同一個執行緒處理並行請求的場景,比如你某個介面中需要呼叫其它 api 介面或讀寫大檔案,傳統同步阻塞和協程非同步的優勢就體現了出來。
詳解 Swoole 協程為什麼適合 I/O 密集型場景
說到協程,就得先簡單說說進程和執行緒,眾所周知進程是很佔用資源的,為了處理請求大量建立進程肯定是得不償失的。而多執行緒應用就比較多了,在 CPU 層面有幾個核心就會執行幾個任務,執行緒一旦建立的多了,就會有執行緒排程的損耗。
協程是在單執行緒基礎上實現的,它可以最大限度利用 CPU 資源,而不會在等待 I/O 時白白浪費。當然,協程數越多佔用的記憶體也就越多,不過這個是可以接受的,相比進程和執行緒,佔用的資源是相對較少的。
使用協程時,遇到讀寫檔案、請求介面等場景,會自動掛起協程,把 CPU 讓給其它協程執行任務,這樣可以提升單執行緒的 CPU 資源利用率,減少浪費,從而提高效能。
協程程式碼範例:
<?php use SwooleCoroutine as co; // 協程 $time = microtime(true); // 建立10個協程 for($i = 0; $i < 10; ++$i) { // 建立協程 go(function() use($i){ co::sleep(1.0); // 模擬請求介面、讀寫檔案等I/O echo $i, PHP_EOL; }); } swoole_event_wait(); echo 'co time:', microtime(true) - $time, ' s', PHP_EOL; // 同步 $time = microtime(true); // 建立10個協程 for($i = 0; $i < 10; ++$i) { sleep(1); // 模擬請求介面、讀寫檔案等I/O echo $i, PHP_EOL; } echo 'sync time:', microtime(true) - $time, ' s', PHP_EOL;
執行結果:
0 9 8 7 6 5 4 3 2 1 co time:1.0087130069733 s 0 1 2 3 4 5 6 7 8 9 sync time:10.010055065155 s
從上面結果可以看出,協程方式執行並不是順序的,效能更高,在sleep時會把當前執行緒的任務執行權交給其他協程。
建立 Http 服務
其實也沒想象中的難,看程式碼:
$http = new swoole_http_server("127.0.0.1", 9501); $http->on('request', function ($request, $response) { $response->end("<h1>Hello Swoole. #".rand(1000, 9999)."</h1>"); }); $http->start();
微服務
Tars是騰訊從2008年到今天一直在使用的後台邏輯層的統一應用框架TAF(Total Application Framework),目前支援C++,Java,PHP,Nodejs語言。該框架為使用者提供了涉及到開發、運維、以及測試的一整套解決方案,幫助一個產品或者服務快速開發、部署、測試、上線。 它集可延伸協定編解碼、高效能RPC通訊框架、名字路由與發現、發布監控、紀錄檔統計、設定管理等於一體,通過它可以快速用微服務的方式構建自己的穩定可靠的分散式應用,並實現完整有效的服務治理。
如有錯誤之處歡迎指出,我是真心想向大家推薦 Swoole!
以上就是php為什麼要用swoole?的詳細內容,更多請關注TW511.COM其它相關文章!