Heim > PHP-Framework > Swoole > Wie funktioniert Swoole?

Wie funktioniert Swoole?

Freigeben: 2019-12-12 15:53:57
Original
3102 Leute haben es durchsucht

Wie funktioniert Swoole?

Einführung in die beiden Betriebsmodi von Swoole:

Single-Threaded-Modus (SWOOLE_BASE)

Dies Der Modus ist ein traditioneller asynchroner, nicht blockierender Server. Es ist vollständig konsistent mit Programmen wie Nginx und Node.js.

Rufen Sie die PHP-Funktion direkt in der Zeitschleife zurück, anstatt die Lieferaufgabe zu versenden. Wenn die Rückruffunktion blockierende Vorgänge enthält, degeneriert der Server in den synchronen Modus. Der Parameter worker_num ist im BASE-Modus weiterhin gültig und es werden mehrere Worker-Prozesse gestartet.

Es gibt keine Rolle des Master-Prozesses im BASE-Modus

Jeder Worker-Prozess übernimmt auch die Verantwortlichkeiten des Reaktor-Threads und des Worker-Prozesses im Prozessmodus

Der Manager-Prozess in BASE Der Modus ist optional. Wenn worker_num=1 festgelegt ist und die Task- und MaxRequest-Funktionen nicht verwendet werden, erstellt die unterste Ebene direkt einen separaten Worker-Prozess, ohne einen Manager-Prozess zu erstellen

Vorteile des BASE-Modus:

Der BASE-Modus hat keinen IPC-Overhead und bietet eine bessere Leistung

Der Code im BASE-Modus ist einfacher und weniger fehleranfällig

Nachteile des BASE-Modus:

TCP-Verbindungen werden beibehalten Wenn also ein Worker-Prozess aufhängt, werden alle Verbindungen in diesem Worker geschlossen.

Eine kleine Anzahl langer TCP-Verbindungen kann nicht von allen Worker-Prozessen verwendet werden.

TCP-Verbindungen sind gebunden an Worker Natürlich verfügen einige Verbindungen in Anwendungen mit langen Verbindungen über große Datenmengen, und die Auslastung des Worker-Prozesses, in dem sich diese Verbindungen befinden, ist sehr hoch. Allerdings ist das Datenvolumen einiger Verbindungen gering, sodass die Belastung des Worker-Prozesses sehr gering ist und verschiedene Worker-Prozesse kein Gleichgewicht erreichen können.

Anwendbare Szenarien des BASE-Modus:

Wenn keine Interaktion zwischen Clientverbindungen erforderlich ist, kann der BASE-Modus verwendet werden. Wie Memcache, HTTP-Server usw.

Empfohlenes Lernen: Swoole-Video-Tutorial

Prozessmodus (SWOOLE_PROCESS)

Der Multiprozessmodus ist der Die komplizierteste Methode, die eine große Anzahl prozessübergreifender Kommunikations- und Prozessmanagementmechanismen verwendet . Geeignet für Szenarien mit sehr komplexer Geschäftslogik. Swoole bietet vollständige Prozessverwaltungs- und Speicherschutzmechanismen. Auch wenn die Geschäftslogik sehr komplex ist, kann sie über einen langen Zeitraum stabil laufen.

Swoole stellt die Pufferfunktion im Reactor-Thread bereit, die mit einer großen Anzahl langsamer Verbindungen und Byte-für-Byte-böswilligen Clients umgehen kann. Darüber hinaus stehen Einstellmöglichkeiten für die CPU-Affinität zur Verfügung, um die Ausführung des Programms effizienter zu gestalten.

Vorteile des Prozessmodus:

Verbindung und Senden von Datenanforderungen sind getrennt, und der Worker-Prozess wird nicht aus dem Gleichgewicht geraten, da einige Verbindungen große Datenmengen und andere kleine Datenmengen aufweisen

Wenn der Worker-Prozess einen schwerwiegenden Fehler sendet, wird die Verbindung nicht unterbrochen

Die Parallelität einzelner Verbindungen kann erreicht werden, es wird nur eine kleine Anzahl von TCP-Verbindungen aufrechterhalten und Anforderungen können gleichzeitig verarbeitet werden mehrere Worker-Prozesse

Nachteile des Prozessmodus:

Es gibt den Overhead von 2 IPCs. Der Master-Prozess und der Worker-Prozess müssen UnixSocket verwenden, um zu kommunizieren

Wird nicht unterstützt einige erweiterte Funktionen, wie sendwait, Pause, Resume und andere Vorgänge

Das obige ist der detaillierte Inhalt vonWie funktioniert Swoole?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage