您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關swoole怎樣重啟,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
在swoole中,我們可以向主進程發送各種不同的信號,主進程根據接收到的信號類型做出不同的處理。
比如下面這幾個
1、kill -SIGTERM|-15 master_pid 終止Swoole程序,一種優雅的終止信號,會待進程執行完當前程序之后中斷,而不是直接干掉進程 2、kill -USR1|-10 master_pid 重啟所有的Worker進程 3、kill -USR2|-12 master_pid 重啟所有的Task Worker進程
當USR1信號被發送給Master進程后,Master進程會將同樣的信號通過Manager進程轉發Worker進程,收到此信號的Worker進程會在處理完正在執行的邏輯之后,釋放進程內存,關閉自己,然后由Manager進程重啟一個新的Worker進程。
新的Worker進程會占用新的內存空間。
場景:
如果是上線的項目,一臺繁忙的后端服務器隨時都在處理請求,如果管理員通過kill進程方式來終止/重啟服務器程序,可能導致剛好代碼執行到一半終止。
這種情況下會產生數據的不一致。
如交易系統中,支付邏輯的下一段是發貨,假設在支付邏輯之后進程被終止了。會導致用戶支付了貨幣,但并沒有發貨,后果非常嚴重。
swoole為我們提供了平滑重啟機制,我們只需要向swoole_server的主進程發送特定的信號,即可完成對server的重啟。
注意事項:
1、更新僅僅只是針對worker進程,在worker 進程當中include 也就是寫在master進程跟manger進程當中更新代碼并不生效,也就是說只有在onWorkerStart回調之后加載的文件,重啟才有意義。
在Worker進程啟動之前就已經加載到內存中的文件,如果想讓它重新生效,只能關閉server再重啟。
2、直接寫在worker代碼當中的邏輯是不會生效的,就算發送了信號也不會,需要通過include方式引入相關的業務邏輯代碼才會生效
關于swoole怎樣重啟就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。