Maison >développement back-end >tutoriel php >Technologie de programmation multi-processus et de gestion de processus en PHP
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.
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.
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失败
} else if ($pid) {
// 父进程
} else {
// 子进程
}
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错误
} else if ($pid) {
// 子进程已结束,$status中是子进程的状态码
} else {
// 子进程还在运行
}
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信号
});
pcntl_sigprocmask(SIG_UNBLOCK, [SIGTERM]);
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.
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!