Heim > PHP-Framework > Swoole > So funktioniert Swoole

So funktioniert Swoole

(*-*)浩
Freigeben: 2019-12-09 09:22:46
Original
2647 Leute haben es durchsucht

So funktioniert Swoole

Single-Threaded-Modus (SWOOLE_BASE)

Dieser Modus ist der traditionelle asynchrone, nicht blockierende Server. Es ist vollständig konsistent mit Programmen wie Nginx und Node.js. (Empfohlenes Lernen: SWOOLE-Video-Tutorial )

Die Funktion, PHP direkt im Zeitzyklus aufzurufen, nicht die Versandaufgabe. 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 ist im BASE-Modus optional und die Task- und MaxRequest-Funktionen werden nicht verwendet. Die unterste Ebene erstellt direkt einen separaten Worker-Prozess und es wird kein Manager-Prozess erstellt

BASE-Vorteile des Modus:

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

Der BASE-Moduscode ist einfacher und weniger fehleranfällig

Nachteile des BASE-Modus:

TCP-Verbindungen werden im Worker-Prozess aufrechterhalten. Wenn also ein Worker-Prozess auflegt, werden alle Verbindungen in diesem Worker geschlossen

Eine kleine Anzahl von lange TCP-Verbindungen Alle Worker-Prozesse können nicht genutzt werden

TCP-Verbindungen sind an Worker gebunden. Einige Verbindungen in Anwendungen mit langen Verbindungen weisen eine große Datenmenge auf, und die Auslastung der Worker-Prozesse, in denen sich diese Verbindungen befinden, ist gering 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.

Prozessmodus (SWOOLE_PROCESS)

Der Multiprozessmodus ist die komplexeste Methode und nutzt eine große Anzahl von prozessübergreifenden Kommunikations- und Prozessmanagementmechanismen. Geeignet für Szenarien mit sehr komplexer Geschäftslogik. Swoole bietet vollständige Prozessverwaltungs- und Speicherschutzmechanismen. Selbst 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 Optionen zur Einstellung der 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 durch die große Datenmenge in einigen Verbindungen verursacht Kleine Datenmenge in einigen Verbindungen. Unausgeglichen.

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

Die Parallelität einer einzelnen Verbindung kann erreicht werden, nur eine kleine Anzahl von TCP Verbindungen bleiben erhalten und Anfragen können gleichzeitig in mehreren Worker-Prozessen verarbeitet werden.

Nachteile des Prozessmodus:

Es gibt den Overhead von 2 IPCs. Der Master-Prozess und der Der Arbeitsprozess muss UnixSocket zur Kommunikation verwenden.

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

Das obige ist der detaillierte Inhalt vonSo 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