Maison > Article > développement back-end > Introduction au cycle de vie de PHP
Mode de fonctionnement de PHP :
Les deux modes de fonctionnement de PHP sont le mode WEB et le mode CLI. Quel que soit le mode, PHP fonctionne de la même manière, fonctionnant comme SAPI.
1. Lorsque nous tapons la commande php dans le terminal, elle utilise la CLI.
C'est comme un serveur Web qui prend en charge php pour terminer la requête. Une fois la requête terminée, le contrôle est rendu au terminal.
2. Lorsque vous utilisez Apache ou un autre serveur Web comme hôte, lorsqu'une requête arrive, PHP prendra en charge l'exécution de la requête. Généralement :
Multi-processus (généralement compilé comme un module Apache pour gérer les requêtes PHP)
Mode multi-thread
Bref processus d'exécution :
1. PHP s'exécute au démarrage d'Apache
2. PHP est connecté à Apache via le module mod_php5.so (en particulier c'est le cas). SAPI (Server Application Programming Interface) ;
3. PHP a trois modules au total : le noyau, le moteur Zend et la couche d'extension
4. , gestion des erreurs et autres opérations associées ;
5. Zend Engine (ZE) est utilisé pour convertir les fichiers sources en langage machine, puis l'exécuter sur une machine virtuelle
6. un ensemble de fonctions, de bibliothèques et de flux que PHP utilise pour effectuer des opérations spécifiques. Par exemple, nous avons besoin de l'extension MySQL pour nous connecter à la base de données MySQL ;
7. Lorsque ZE exécute le programme, il peut avoir besoin de se connecter à plusieurs extensions. À ce moment, ZE donnera le contrôle à l'extension et. renvoyez-le après avoir traité la tâche spécifique ;
8. Enfin, ZE renvoie les résultats du programme en cours d'exécution au noyau PHP, qui transmet ensuite les résultats à la couche SAPI et les envoie enfin au navigateur.
Plusieurs étapes d'exécution de PHP :
SAPI exécutant PHP passe par les étapes suivantes :
Phase d'initialisation du module. (Init du module) :
C'est-à-dire appeler la méthode dans PHP_MINIT_FUNCTION dans chaque code source d'extension pour initialiser le module, appliquer certaines variables requises par le module, allouer de la mémoire, etc.
2. Phase d'initialisation de la requête (Request init) :
Après réception de la requête du client, la méthode dans PHP_RINIT_FUNCTION de chaque extension est appelée pour initialiser l'environnement d'exécution du script PHP.
3. Exécutez le script PHP
4. Request Shutdown :
À ce moment, la méthode PHP_RSHUTDOWN_FUNCTION de chaque extension est appelée pour nettoyer le site de requête, et ZE démarre. pour recycler les variables et la mémoire.
5. Arrêt du module :
Lorsque le serveur Web se ferme ou que le script de ligne de commande est exécuté et se termine, la méthode PHP_MSHUTDOWN_FUNCTION dans le code source de l'extension sera appelée
Cycle de vie SAPI dans diverses circonstances
1. Cycle de vie SAPI à processus unique. (CGI)
Mode CLI/CGI PHP appartient au mode SAPI mono-processus. Ce type de demande est clôturé après avoir traité une seule fois la demande. C'est-à-dire que chaque requête répétera ces étapes : start - request start - request close - end. Vous pouvez constater que l’initialisation de l’extension consomme beaucoup de ressources.
2. Cycle de vie SAPI multi-processus. (Méthode perfork de MPM)
Habituellement, PHP est compilé dans un module d'Apache pour gérer les requêtes PHP (mod_php). Apache adopte généralement le mode multi-processus. Après le démarrage d'Apache, il lancera plusieurs processus enfants (Apache peut spécifier le nombre de processus à démarrer). L'espace mémoire de chaque processus est indépendant, et chaque processus enfant passera par les étapes de début et de fin dès qu'il sera focké.
3. Cycle de vie SAPI multithread. (Processus unique en mode de travail FastCGI ou MPM)
Le mode multi-thread est similaire à un processus en multi-processus. Dans ce mode, un seul processus serveur est en cours d'exécution, mais plusieurs s'exécuteront en même temps. Les threads peuvent réduire une certaine surcharge de ressources. L'initialisation et l'arrêt du module ne doivent être exécutés qu'une seule fois. En raison des caractéristiques uniques des threads, il est possible de partager certaines données entre les requêtes.
Recommandations associées :
Tutoriel vidéo PHP : https://www.php.cn/course/list/29/ tapez/2.html
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!