這篇文章給大家分享的是有關(guān)swoole平滑重啟的方法的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
成都創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比周村網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式周村網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋周村地區(qū)。費用合理售后完善,十余年實體公司更值得信賴。
swoole 平滑重啟
在swoole中,我們可以向主進(jìn)程發(fā)送各種不同的信號,主進(jìn)程根據(jù)接收到的信號類型做出不同的處理。比如下面這幾個
SIGTERM,一種優(yōu)雅的終止信號,會待進(jìn)程執(zhí)行完當(dāng)前程序之后中斷,而不是直接干掉進(jìn)程
SIGUSR1,將平穩(wěn)的重啟所有的Worker進(jìn)程
SIGUSR2,將平穩(wěn)的重啟所有的Task進(jìn)程
如果我們要實現(xiàn)重啟server,只需要向主進(jìn)程發(fā)送SIGUSR1信號就好了。
平滑重啟的原理是當(dāng)主進(jìn)程收到SIGUSR1信號時,主進(jìn)程就會向一個子進(jìn)程發(fā)送安全退出的信號,所謂的安全退出的意思是主進(jìn)程并不會直接把Worker進(jìn)程殺死,而是等這個子進(jìn)程處理完手上的工作之后,再讓其光榮的“退休”,最后再拉起新的子進(jìn)程(重新載入新的PHP程序代碼)。
然后再向其他子進(jìn)程發(fā)送“退休”命令,就這樣一個接一個的重啟所有的子進(jìn)程。
我們注意到,平滑重啟實際上就是讓舊的子進(jìn)程逐個退出并重新創(chuàng)建新的進(jìn)程。為了在平滑重啟時不影響到用戶,這就要求進(jìn)程中不要保存用戶相關(guān)的狀態(tài)信息,即業(yè)務(wù)進(jìn)程最好是無狀態(tài)的,避免由于進(jìn)程退出導(dǎo)致信息丟失。
感覺很美好的樣子,凡是重啟只要簡單的向主進(jìn)程發(fā)送信號就完事了唄。
理想很豐滿,現(xiàn)實并非如此。
在swoole中,重啟只能針對Worker進(jìn)程啟動之后載入的文件才有效!什么意思呢,就是說只有在onWorkerStart回調(diào)之后加載的文件,重啟才有意義。在Worker進(jìn)程啟動之前就已經(jīng)加載到內(nèi)存中的文件,如果想讓它重新生效,還是只能乖乖的關(guān)閉server再重啟。
說了這么多,我們寫個例子看看到底怎么樣向主進(jìn)程發(fā)送SIGUSR1信號以便有效重啟Worker進(jìn)程。
首先我們創(chuàng)建一個Test類,用于處理onReceive回調(diào)的數(shù)據(jù),為什么要把onReceive回調(diào)的業(yè)務(wù)拿出來單獨寫,看完例子你就明白了。
在Test::run方法中,我們第一步僅僅是echo輸出swoole_server接收到的數(shù)據(jù)。
當(dāng)前目錄下我們創(chuàng)建一個swoole_server的類NoReload.php
_serv = new Swoole\Server("127.0.0.1", 9501); $this->_serv->set([ 'worker_num' => 1, ]); $this->_serv->on('Receive', [$this, 'onReceive']); $this->_test = new Test; } /** * start server */ public function start() { $this->_serv->start(); } public function onReceive($serv, $fd, $fromId, $data) { $this->_test->run($data); } } $noReload = new NoReload; $noReload->start();特別提醒:我們在初始化swoole_server的時候的寫法是命名空間的寫法
new Swoole\Server該種風(fēng)格的寫法等同于下劃線寫法 ,swoole對這兩種風(fēng)格的寫法都支持
new swoole_server此外我們看下server的代碼邏輯:類定義之前require_once了Test.php,初始化的時候設(shè)置了一個Worker進(jìn)程,注冊了NoReload::onReceive方法為swoole_server的onReceive回調(diào),在onReceive回調(diào)內(nèi)接收到的數(shù)據(jù)傳遞給了Test::run方法處理。
感謝各位的閱讀!關(guān)于swoole平滑重啟的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
當(dāng)前標(biāo)題:swoole平滑重啟的方法
本文地址:http://weahome.cn/article/isgeeg.html