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!