Offiziell heißt es, dass alle Worker- und Tasker-Prozesse durch
$swoole->reload() oder swoole_process::kill($) reibungslos neu gestartet werden können master_pid , SIGUSR1) oder direkt kill -USR1 master_pid usw.
Empfohlenes Lernen: swoole-Video-Tutorial
Einfacher Test
Öffnen Sie einen swoole_http_server, sowohl der Worker-Prozess als auch der Tasker-Prozess 1 Dann initiiert der Browser eine HTTP-Anfrage und der Inhalt der Anfrage ist nur ein einfacher Ruhezustand. Über die Schlaffunktion sollte er in der Lage sein, anzuzeigen, dass sich der Arbeiter, der diese Anfrage verarbeitet, im Arbeitsstatus befindet, und dann einen Neuladevorgang durchzuführen die Schlafperiode.
Wenn eine Anfrage zum ersten Mal an den Swoole-Server initiiert wird, plant der Managerprozess die Anfrage für die Verarbeitung an den Worker. Wenn dann während der Ruhephase der Worker-Verarbeitung eine weitere Anfrage eingeht, wird die Der Manager sendet die nachfolgende Anfrage nicht an den einzigen Arbeitsprozess, da der Arbeitsprozess noch mit der Verarbeitung der ersten Anfrage beschäftigt ist. Dies kann mit einem einfachen Test bestätigt werden.
HTTP-Anfragen werden einfach weiter unten weitergeleitet. Da das Easyswoole-Framework verwendet wird, ist die Ausführung des Befehls php easyswoole reload all tatsächlich kill -USR1 master_pid.
Serverkonfiguration
$swoole_server->set([ 'worker_num' => 1, 'task_worker_num' => 1, 'reload_async' => true, 'max
Test starten
1. Die Aufgabenlogik wird im Worker-Prozess geschrieben
http-Methode
public function test() { $start = microtime(true); echo '请求开始时间:' . $start . PHP_EOL; echo 'pid: ' . getmypid() . PHP_EOL; sleep(30); # 这里睡眠脚本作测试 echo 'finish sleep' . PHP_EOL; $end = microtime(true); echo '请求结束时间:' . $end . PHP_EOL; $this->writeJson(0, round(($end - $start), 3)); }
Monitor onWorkerStart ()Methode
EventHelper::registerWithAdd(ServerManager::getInstance()->getMainEventRegister(),EventRegister::onWorkerStart,function (\swoole_server $server,$workerId){ if(PHP_OS != 'Darwin'){ $name = Config::getInstance()->getConf('SERVER_NAME'); if( ($workerId < Config::getInstance()->getConf('MAIN_SERVER.SETTING.worker_num')) && $workerId >= 0){ $type = 'Worker'; }else{ $type = 'TaskWorker'; } cli_set_process_title("{$name}.{$type}.{$workerId}"); } # 下面是打印测试的 if ($type == 'Worker') { echo "这个是reload worker的时间:" . microtime(true) . "\n"; } if ($type == 'TaskWorker') { echo "这个是reload TaskWorker的时间:" . microtime(true) . "\n"; } });
Testergebnis:
Startzeit anfordern: 1566880257.9533 # Hier wird die http-Schnittstelle angefordert, nämlich test()
pid: 42108
dies ist die Zeit zum Neuladen von TaskWorker: 1566880265.1501 # Dies ist die Zeit zum Ausführen von php easyswoole reload all Da der Tasker inaktiv ist und keine Aufgaben hat, kann er sofort neu geladen werden.
Dies ist die Nachladezeit des Workers: 1566880275.1524 # Dies ist die Nachladezeit des Workers, da sich Sleep(30) in test() befindet und max_wait_time überschreitet, wartet die unterste Ebene nicht weiter auf die Aufgabe des Workers abgeschlossen werden, und direkt Der alte Worker wurde beendet, aber „Schlaf beenden“ wurde nicht gedruckt und ein neuer Worker wurde erstellt.
# Aber warum dauert es 10 Sekunden, den Worker neu zu erstellen? Max_wait_time ist auf 5s eingestellt? ? Das ist etwas, was ich nie herausfinden konnte.
Das obige ist der detaillierte Inhalt vonSo starten Sie Swoole neu. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!