Heim  >  Artikel  >  PHP-Framework  >  So starten Sie Swoole neu

So starten Sie Swoole neu

尚
Original
2019-12-10 15:20:195410Durchsuche

So starten Sie Swoole neu

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn