Technologie de programmation multi-processus et de gestion de processus en PHP

王林
Libérer: 2023-05-11 18:52:01
original
816 Les gens l'ont consulté
  1. Avant-propos

En tant que langage de programmation populaire, PHP a été largement utilisé dans divers domaines. Dans le cas d'une concurrence élevée, d'un volume de données important et d'une charge élevée, les caractéristiques monothread de PHP entraîneront des goulots d'étranglement en termes de performances. Afin d'utiliser pleinement toutes les ressources CPU, mémoire et IO de la machine et d'améliorer les performances et l'évolutivité du programme, la technologie multi-processus doit être utilisée.

  1. Qu'est-ce que la programmation multi-processus ?

Dans le système d'exploitation, un processus fait référence à un programme en cours d'exécution. La programmation multi-processus fait référence à la division d'un programme en plusieurs processus pour son exécution. Chaque processus est indépendant les uns des autres et peut être exécuté simultanément, améliorant ainsi le débit et les capacités de traitement du programme.

En PHP, la bibliothèque d'extensions pcntl est généralement utilisée pour implémenter la programmation multi-processus.

  1. Comment utiliser la bibliothèque d'extensions PCNTL ?

Tout d'abord, vous devez activer la bibliothèque d'extensions pcntl dans le fichier php.ini.

extension=pcntl.so

Utilisez la fonction pcntl_fork() pour créer un nouveau processus enfant. Le processus enfant et le processus parent partagent le segment de code, le segment de données et le segment de pile, mais chacun dispose d'un espace d'exécution et d'une identité de processus indépendants.

$pid = pcntl_fork();
if ($pid == -1) {

// fork失败
Copier après la connexion

} else if ($pid) {

// 父进程
Copier après la connexion

} else {

// 子进程
Copier après la connexion

}

Utilisez la fonction pcntl_waitpid() pour wait Le processus enfant se termine et le code d'état renvoyé par le processus enfant est obtenu.

$status = null;
$pid = pcntl_waitpid($child_pid, $status, WNOHANG);
if ($pid == -1) {

// waitpid错误
Copier après la connexion

} else if ($pid) {

// 子进程已结束,$status中是子进程的状态码
Copier après la connexion

} else {

// 子进程还在运行
Copier après la connexion

}

Utilisez la fonction pcntl_sigprocmask() pour masquer/restaurer le signal reçu par le processus.

pcntl_sigprocmask(SIG_BLOCK, [SIGTERM]);
// Après avoir reçu le signal SIGTERM, le processus ne se terminera pas immédiatement, mais attendra que le processus soit traité avant de quitter
pcntl_signal(SIGTERM, function() {

// 处理SIGTERM信号
Copier après la connexion

});
pcntl_sigprocmask(SIG_UNBLOCK, [SIGTERM]);

  1. Technologie de gestion des processus

Dans les applications pratiques, les processus doivent être gérés, y compris le démarrage, l'arrêt, le redémarrage, la surveillance et d'autres fonctions du processus. Les technologies de gestion de processus couramment utilisées sont les suivantes :

4.1 Supervisord

Supervisor est un gestionnaire de processus qui peut démarrer, arrêter, redémarrer et surveiller plusieurs processus. Il dispose d'un client et d'un serveur. Le client envoie des commandes de contrôle au serveur et le serveur contrôle l'état d'exécution du processus. Supervisor prend également en charge les groupes de processus, la journalisation, le redémarrage automatique si le programme ne démarre pas, les scripts personnalisés et d'autres fonctions.

Le fichier de configuration de Supervisor est très simple, utilisant le format INI et facile à maintenir. Voici un exemple de fichier de configuration de superviseur :

[program:myprogram]
command=/usr/bin/php /path/to/myprogram.php
process_name=%(program_name)s_%(process_num)02d
numprocs =4
directory=/path/to/myprogram
autostart=true
autorestart=true
user=myuser
stdout_logfile=/var/log/myprogram.log
stderr_logfile=/var/log/myprogram.err

4.2 Systemd

Systemd Il s'agit d'un système d'initialisation utilisé pour remplacer sysvinit et upstart, et peut également être utilisé comme gestionnaire de processus. Il peut démarrer, arrêter, redémarrer et surveiller plusieurs processus et prend en charge des fonctions telles que les dépendances de processus, le redémarrage automatique, la requête sur l'état du processus et les restrictions de ressources.

Le fichier de configuration de Systemd est relativement complexe et utilise le format de fichier systemd.units. Voici un exemple de fichier de configuration Systemd :

[Unit]
Description=myprogram
After=network.target

[Service]
Type=simple
ExecStart=/usr/bin/php /path/to/myprogram .php
PIDFile=/run/myprogram.pid
Restart=on-failure
User=myuser

[Install]
WantedBy=multi-user.target

4.3 Docker

Docker est un moteur de conteneur d'applications open source qui peut Créez, déployez et exécutez rapidement des conteneurs. Dans Docker, chaque conteneur est un processus indépendant et le conteneur peut être géré à l'aide des outils de ligne de commande ou de l'API de Docker.

Docker fournit un environnement de type système d'exploitation, comprenant un système de fichiers, un espace de processus, un réseau, etc., dans lequel n'importe quelle application peut être exécutée. Docker prend également en charge le déploiement distribué, l'orchestration de conteneurs, l'entrepôt d'images et d'autres fonctions.

  1. Résumé

La programmation multi-processus et la technologie de gestion des processus sont largement utilisées dans la programmation réseau et la programmation système. L'utilisation de plusieurs processus peut améliorer les capacités de traitement simultanées et le débit du programme. L'utilisation du gestionnaire de processus peut gérer plus facilement le démarrage, l'arrêt, le redémarrage, la surveillance et d'autres opérations du processus. Dans les applications pratiques, les technologies appropriées doivent être sélectionnées pour le développement et le déploiement en fonction des conditions réelles.

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal