Maison > Article > développement back-end > Comparaison de PHP-FPM et Swoole
J'ai vu quelques articles sur le swoole il y a quelques jours, et je suis ici pour me joindre à la fête aujourd'hui. Mon niveau est limité et ma compréhension des détails n'est peut-être pas au rendez-vous. J'invite tout le monde à m'aider à ajouter et à corriger.
PHP-FPM
Les premières versions de PHP n'avaient pas de serveur WEB intégré, mais fournissaient SAPI (API serveur) pour la connexion tierce. Le désormais très populaire php-fpm gère la communication entre PHP et les serveurs WEB tiers via le protocole FastCGI. Par exemple, la combinaison de Nginx + php-fpm, fpm exécuté de cette manière est en mode Master/Worker, démarrant un processus Master pour surveiller les requêtes de Nginx, puis bifurquant plusieurs processus Worker pour gérer les requêtes. Chaque processus Worker ne peut traiter qu'une seule requête. Le cycle de vie d'un seul processus est à peu près le suivant :
1.
2. Demande d'initialisation. La requête ici signifie demander à PHP d'exécuter du code, pas une requête HTTP.
3. Exécutez le script PHP.
4. Terminez la demande.
5. Fermez le module.
Le modèle multi-processus s'appuie sur le nombre de processus pour résoudre les problèmes de concurrence. Un processus ne peut gérer qu'une seule connexion. Lorsqu'un grand nombre de processus sont démarrés, la consommation de planification des processus peut représenter des dizaines, voire 100 %. du CPU, comme le problème C10K, le modèle multi-processus est insuffisant.
Swoole
Swoole utilise également le mode Master/Worker. La différence est que le processus Master a plusieurs threads Reactor et que le Master n'est qu'un générateur d'événements, responsable. pour écouter le handle du Socket dans les événements. Worker s'exécute de manière multi-processus, reçoit des requêtes des threads Reactor et exécute des fonctions de rappel (écrites en PHP). Le processus de démarrage du processus Master est grossièrement :
1. Initialiser le module.
2. Demande d'initialisation. Étant donné que swoole doit être exécuté via le cli, les variables globales de PHP, telles que $_SERVER, $_POST, $_GET, etc., ne seront pas initialisées lors de l'initialisation de la requête.
3. Exécutez le script PHP. Y compris l'analyse lexicale et syntaxique, l'initialisation des variables, des fonctions, des classes, etc., le Maître entre dans l'état d'écoute et ne terminera pas le processus.
Principe de l'accélération Swoole
● Reactor (la méthode de réutilisation des E/S d'epoll) est responsable de la surveillance des changements d'événements des handles de Socket pour résoudre les problèmes de concurrence élevée.
● Gagnez du temps sur l'initialisation du code PHP grâce à la mémoire résidente Lorsque vous utilisez des frameworks volumineux, l'effet d'accélération de l'utilisation de swoole est très évident.
Comparaison des différences
PHP-FPM
● Processus principal maître / Mode multi-processus Worker.
● Démarrez le maître et écoutez les requêtes transmises depuis Nginx via le protocole FastCGI.
● Chaque processus Worker correspond à une seule connexion, qui sert à exécuter du code PHP complet.
● Une fois le code PHP exécuté, toute la mémoire occupée sera détruite, et la prochaine requête nécessitera une réinitialisation et d'autres opérations fastidieuses.
● Uniquement pour le serveur HTTP.
Swoole
● Processus principal maître (composé de plusieurs threads Reactor)/Mode Worker multi-processus (ou multi-thread)
● Démarrer Master , initialisez le code PHP et le Reactor surveille les changements d'événement du handle Socket.
● Le thread principal de Reactor est responsable de l'équilibrage des multi-threads, et le processus Manager gère plusieurs processus Worker, y compris les processus TaskWorker.
● Chaque Worker accepte les requêtes de Reactor et n'a besoin que d'exécuter le code PHP dans la partie fonction de rappel.
● Le code d'initialisation PHP n'est exécuté qu'une seule fois au démarrage du Maître. Le Maître entre dans l'état d'écoute et ne termine pas le processus.
● Non seulement peut être utilisé pour le serveur HTTP, mais peut également établir des connexions TCP et des connexions WebSocket.
Ce qui précède sert principalement à comparer les principales machines opérationnelles. Les différences répertoriées ne sont que les points qui me viennent à l'esprit pour le moment. S'il y a des points manqués, aidez-moi à les ajouter ~
.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!