Heim  >  Artikel  >  PHP-Framework  >  Unterstützt swoole Multithreading?

Unterstützt swoole Multithreading?

青灯夜游
青灯夜游Original
2019-12-25 18:18:244192Durchsuche

Unterstützt swoole Multithreading?

Reaktor-Thread

Der Hauptprozess von SwooleServer ist ein Multithread-Programm. Es gibt eine sehr wichtige Gruppe von Threads, die als Reaktor-Threads bezeichnet werden. Es ist der Thread, der tatsächlich TCP-Verbindungen verarbeitet und Daten sendet und empfängt.

Nach dem Akzeptieren einer neuen Verbindung weist Swooles Hauptthread die Verbindung einem festen Reactor-Thread zu, und dieser Thread ist für die Überwachung des Sockets verantwortlich. Lesen Sie die Daten, wenn der Socket lesbar ist, führen Sie eine Protokollanalyse durch und übermitteln Sie die Anfrage an den Worker-Prozess. Senden Sie Daten an den TCP-Client, wenn der Socket beschreibbar ist.

Die Zuordnung wird als fd % serv->reactor_num berechnet

Da die PHP-Sprache kein Multithreading unterstützt, verwendet Swoole den Multiprozessmodus. Im Multiprozessmodus liegt eine Prozessspeicherisolation vor. Wenn globale Variablen und superglobale Variablen im Arbeitsprozess geändert werden, sind sie in anderen Prozessen ungültig.

Wenn worker_num=1 gesetzt ist, gibt es keine Prozessisolation und Sie können globale Variablen zum Speichern von Daten verwenden

Prozessisolation

$fds = array();
$server->on('connect', function ($server, $fd){
    echo "connection open: {$fd}\n";
    global $fds;
    $fds[] = $fd;
    var_dump($fds);
});

Obwohl $fds eine globale Variable ist, ist sie nur innerhalb des aktuellen Prozesses gültig. Die unterste Ebene des Swoole-Servers erstellt mehrere Worker-Prozesse. Der in var_dump($fds) gedruckte Wert enthält nur teilweise verbundene fds.

Die entsprechende Lösung besteht darin, externe Speicherdienste zu verwenden:

Datenbank wie: MySQL, MongoDB
Cache-Server wie: Redis, Memcache
Festplattendateien müssen gesperrt werden, wenn mehrere Prozesse gleichzeitig lesen und schreiben

Gewöhnliche Datenbank- und Festplattendateivorgänge haben viel E/A-Wartezeit. Daher wird empfohlen, Folgendes zu verwenden:

Redis In-Memory-Datenbank, sehr schnelle Lese- und Schreibgeschwindigkeiten
/dev/shm In-Memory-Dateisystem, alle Lese- und Schreibvorgänge werden im Speicher abgeschlossen, kein IO-Verbrauch, Leistung extrem hoch
Neben der Nutzung von Speicher können Sie auch Shared Memory zum Speichern von Daten nutzen

Empfohlenes Lernen: Swoole-Video-Tutorial

Das obige ist der detaillierte Inhalt vonUnterstützt swoole Multithreading?. 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