這篇文章給大家分享的是有關swoole協程和異步區別是什么的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
成都創新互聯公司,為您提供網站建設公司、重慶網站制作、網站營銷推廣、網站開發設計,對服務人造霧等多個行業擁有豐富的網站建設及推廣經驗。成都創新互聯公司網站建設公司成立于2013年,提供專業網站制作報價服務,我們深知市場的競爭激烈,認真對待每位客戶,為客戶提供賞心悅目的作品。 與客戶共同發展進步,是我們永遠的責任!從4.0版本開始Swoole提供了完整的協程(Coroutine)+ 通道(Channel)特性,帶來全新的CSP編程模型。
應用層可使用完全同步的編程方式,底層自動實現異步IO。
go(function () { $redis = new Swoole\Coroutine\Redis(); $redis->connect('127.0.0.1', 6379); $val = $redis->get('key'); });
4.0.0或更高版本僅支持PHP7
4.0.1版本開始去除了--enable-coroutine編譯選項,改為動態配置
協程可以理解為純用戶態的線程,其通過協作而不是搶占來進行切換。相對于進程或者線程,協程所有的操作都可以在用戶態完成,創建和切換的消耗更低。
Swoole可以為每一個請求創建對應的協程,根據IO的狀態來合理的調度協程,這會帶來了以下優勢:
開發者可以無感知的用同步的代碼編寫方式達到異步IO的效果和性能,避免了傳統異步回調所帶來的離散的代碼邏輯和陷入多層回調中導致代碼無法維護
同時由于底層封裝了協程,所以對比傳統的PHP層協程框架,開發者不需要使用yield關鍵詞來標識一個協程IO操作,所以不再需要對yield的語義進行深入理解以及對每一級的調用都修改為yield,這極大的提高了開發效率
可以滿足大部分開發者的需求。對于私有協議,開發者可以使用協程的TCP或者UDP接口去方便的封裝。
在Server程序中如果需要執行很耗時的操作,比如一個聊天服務器發送廣播,Web服務器中發送郵件。如果直接去執行這些函數就會阻塞當前進程,導致服務器響應變慢。
Swoole提供了異步任務處理的功能,可以投遞一個異步任務到TaskWorker進程池中執行,不影響當前請求的處理速度。
程序代碼
基于第一個TCP服務器,只需要增加onTask和onFinish3個事件回調函數即可。另外需要設置task進程數量,可以根據任務的耗時和任務量配置適量的task進程。
$serv = new swoole_server("127.0.0.1", 9501); //設置異步任務的工作進程數量 $serv->set(array('task_worker_num' => 4)); $serv->on('receive', function($serv, $fd, $from_id, $data) { //投遞異步任務 $task_id = $serv->task($data); echo "Dispath AsyncTask: id=$task_id\n"; }); //處理異步任務 $serv->on('task', function ($serv, $task_id, $from_id, $data) { echo "New AsyncTask[id=$task_id]".PHP_EOL; //返回任務執行的結果 $serv->finish("$data -> OK"); }); //處理異步任務的結果 $serv->on('finish', function ($serv, $task_id, $data) { echo "AsyncTask[$task_id] Finish: $data".PHP_EOL; }); $serv->start();
調用$serv->task()后,程序立即返回,繼續向下執行代碼。onTask回調函數Task進程池內被異步執行。執行完成后調用$serv->finish()返回結果。
感謝各位的閱讀!關于“swoole協程和異步區別是什么”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
文章題目:swoole協程和異步區別是什么-創新互聯
文章路徑:http://m.newbst.com/article34/egepe.html
成都網站建設公司_創新互聯,為您提供網站收錄、定制開發、網站制作、網站策劃、商城網站、手機網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯