Heim >PHP-Framework >Swoole >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 erstelltBASE-Vorteile des Modus:
Der BASE-Modus hat keinen IPC-Overhead und eine bessere LeistungDer BASE-Moduscode ist einfacher und weniger fehleranfälligNachteile des BASE-Modus:
TCP-Verbindungen werden im Worker-Prozess aufrechterhalten. Wenn also ein Worker-Prozess auflegt, werden alle Verbindungen in diesem Worker geschlossenEine 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 nichtDas obige ist der detaillierte Inhalt vonSo funktioniert Swoole. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!