小編給大家分享一下swoole的worker如何調(diào)用,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
目前創(chuàng)新互聯(lián)已為近千家的企業(yè)提供了網(wǎng)站建設、域名、網(wǎng)絡空間、網(wǎng)站改版維護、企業(yè)網(wǎng)站設計、瑪納斯網(wǎng)站維護等服務,公司將堅持客戶導向、應用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
Swoole提供了完善的進程管理機制,當Worker進程異常退出,如發(fā)生PHP的致命錯誤、被其他程序誤殺,或達到max_request次數(shù)之后正常退出。
主進程會重新拉起新的Worker進程。Worker進程內(nèi)可以像普通的apache+php或者php-fpm中寫代碼。不需要像Node.js那樣寫異步回調(diào)的代碼。
Worker進程
接受由Reactor線程投遞的請求數(shù)據(jù)包,并執(zhí)行PHP回調(diào)函數(shù)處理數(shù)據(jù)
生成響應數(shù)據(jù)并發(fā)給Reactor線程,由Reactor線程發(fā)送給TCP客戶端
可以是異步非阻塞模式,也可以是同步阻塞模式
Worker以多進程的方式運行
worker_num
描述:指定啟動的worker進程數(shù)。
說明:swoole是master-> n * worker的模式,開啟的worker進程數(shù)越多,server負載能力越大,但是相應的server占有的內(nèi)存也會更多。同時,當worker進程數(shù)過多時,進程間切換帶來的系統(tǒng)開銷也會更大。因此建議開啟的worker進程數(shù)為cpu核數(shù)的1-4倍。
示例:
'worker_num' => 8
看完了這篇文章,相信你對“swoole的worker如何調(diào)用”有了一定的了解,如果想了解更多相關知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!