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!