Maison  >  Article  >  cadre php  >  Comment fonctionne le swool ?

Comment fonctionne le swool ?

尚
original
2019-12-12 15:53:573055parcourir

Comment fonctionne le swool ?

Présentation des deux modes de fonctionnement de swoole :

Mode mono-thread (SWOOLE_BASE)

Ce le mode est le serveur asynchrone non bloquant traditionnel. Il est totalement cohérent avec des programmes tels que Nginx et Node.js.

Rappelez directement la fonction PHP dans la boucle temporelle au lieu de dispatcher la tâche de livraison. S'il y a des opérations bloquantes dans la fonction de rappel, le serveur dégénérera en mode synchrone. Le paramètre worker_num est toujours valide en mode BASE et plusieurs processus Worker seront démarrés.

Il n'y a pas de rôle de processus Maître en mode BASE

Chaque processus Worker assume également les responsabilités du thread Reactor et du processus Worker en mode Processus

Le processus Manager en BASE mode est facultatif, lorsque worker_num=1 est défini et que les fonctionnalités Task et MaxRequest ne sont pas utilisées, la couche inférieure créera directement un processus Worker distinct sans créer de processus Manager

Avantages du mode BASE :

Le mode BASE n'a pas de surcharge IPC et offre de meilleures performances

Le code du mode BASE est plus simple et moins sujet aux erreurs

Inconvénients du mode BASE :

Les connexions TCP sont maintenues dans le processus Worker, donc lorsqu'un processus Worker raccroche, toutes les connexions de ce Worker seront fermées

Un petit nombre de connexions TCP longues ne peuvent pas être utilisées par tous les processus Worker

Les connexions TCP sont liées aux Workers Certaines connexions dans les applications à connexion longue contiennent une grande quantité de données et la charge du processus Worker où se trouvent ces connexions sera très élevée. Cependant, le volume de données de certaines connexions est faible, de sorte que la charge sur le processus Worker sera très faible et que les différents processus Worker ne pourront pas atteindre l'équilibre.

Scénarios applicables du mode BASE :

S'il n'y a pas besoin d'interaction entre les connexions client, le mode BASE peut être utilisé. Tels que Memcache, serveur HTTP, etc.

Apprentissage recommandé : Tutoriel vidéo swoole

Mode processus (SWOOLE_PROCESS)

Le mode multi-processus est le méthode la plus compliquée, utilisant un grand nombre de mécanismes de communication inter-processus et de gestion des processus. Convient aux scénarios avec une logique métier très complexe. Swoole fournit des mécanismes complets de gestion des processus et de protection de la mémoire. Même lorsque la logique métier est très complexe, elle peut fonctionner de manière stable pendant une longue période.

Swoole fournit la fonction Buffer dans le thread Reactor, qui peut gérer un grand nombre de connexions lentes et de clients malveillants octet par octet. De plus, des options de configuration de l'affinité du processeur sont fournies pour rendre le programme plus efficace.

Avantages du mode processus :

La connexion et l'envoi des demandes de données sont séparés, et le processus Worker ne sera pas déséquilibré car certaines connexions ont de grandes quantités de données et d'autres ont de petites quantités de données

Lorsque le processus Worker envoie une erreur fatale, la connexion ne sera pas coupée

Une simultanéité de connexion unique peut être obtenue, seul un petit nombre de connexions TCP est maintenue et les demandes peuvent être traitées simultanément dans plusieurs processus de travail

Inconvénients du mode processus :

Il y a une surcharge de 2 IPC. Le processus maître et le processus de travail doivent utiliser UnixSocket pour communiquer

Ne prend pas en charge. certaines fonctions avancées, telles que sendwait, pause, reprise et autres opérations

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Article précédent:Swoole est-il un framework ?Article suivant:Swoole est-il un framework ?