PHP est connu comme un langage monothread, ce qui signifie qu'il ne peut exécuter qu'une seule tâche à la fois au sein d'un seul processus. Cependant, Laravel fournit un système de file d'attente robuste pour gérer plusieurs tâches de manière « asynchrone ». Si PHP est monothread, comment Laravel réalise-t-il cette magie ? Décomposons-le en termes simples.
Avant de plonger dans les files d'attente, nous devons comprendre ce qu'est un processus PHP.
Un processus est comme un travailleur embauché pour accomplir une tâche. Lorsque vous exécutez un script PHP (par exemple php my_script.php), le système d'exploitation crée un nouveau processus. Ce processus :
echo "Hello World!";
Lorsque vous exécutez ce script, PHP démarre un processus, affiche « Hello World ! », puis le processus se termine.
Dans les applications web :
PHP est monothread, ce qui signifie :
echo "Task 1"; // Waits for Task 1 to finish before starting Task 2 echo "Task 2";
PHP exécute la tâche 1 en premier. Ce n'est qu'une fois terminé qu'il passe à la tâche 2. Ce comportement est différent des langages comme JavaScript, où les tâches peuvent s'exécuter en parallèle dans le même processus.
Le système de file d'attente de Laravel vous permet d'exécuter plusieurs tâches en arrière-plan sans bloquer l'application principale. Par exemple :
Mais PHP ne peut gérer qu’une seule tâche à la fois, n’est-ce pas ? Comment Laravel fait-il paraître asynchrone ? La réponse réside dans les travailleurs et les processus multiples.
Un travailleur dans Laravel est un processus PHP de longue durée qui écoute les tâches dans une file d'attente et les exécute.
Lorsque vous exécutez la commande :
php artisan queue:work
Un nouveau processus PHP (ou travailleur) démarre. Ce processus :
Laravel atteint un comportement « asynchrone » en exécutant plusieurs nœuds de calcul en même temps. Chaque travailleur est un processus PHP distinct.
Voici comment cela fonctionne :
Lorsque vous exécutez php artisan queue:work, cela commence avec un seul travailleur (un processus PHP).
Vous pouvez démarrer plusieurs travailleurs pour traiter des tâches en parallèle sur différents onglets localement et en production en utilisant le gestionnaire de processus comme le superviseur.
Cela démarrera plusieurs processus PHP. Chaque travailleur gère les tâches de manière indépendante, ce qui donne l'impression que les tâches s'exécutent simultanément.
Lorsque vous mettez une tâche en file d'attente dans Laravel, voici ce qui se passe étape par étape :
Si le travail échoue, Laravel le réessaye ou le déplace vers une liste de « travaux ayant échoué » (en fonction de votre configuration).
Exemple de scénario : envoi d'e-mails
Imaginez que vous ayez une application Laravel dans laquelle les utilisateurs soumettent un formulaire de contact. Lorsque le formulaire est soumis :
En arrière-plan :
En production, les travailleurs de Laravel sont gérés par des outils comme Supervisor. Le superviseur fait fonctionner les travailleurs 24 heures sur 24, 7 jours sur 7 et les redémarre en cas de panne.
Exemple de configuration du superviseur :
echo "Hello World!";
commande : exécute la commande queue:work.
numprocs=5 : démarre 5 workers (5 processus PHP) pour gérer les tâches.
Techniquement, les files d'attente Laravel ne sont pas asynchrones dans la manière dont JavaScript ou Node.js gèrent les tâches. Au lieu de cela :
Chaque travailleur gère un travail à la fois.
Plusieurs travailleurs (processus) assurent le parallélisme, donnant l'apparence d'une exécution asynchrone.
Le système de file d'attente de Laravel est un moyen intelligent de gérer les tâches en arrière-plan, améliorant ainsi les performances des applications et l'expérience utilisateur. Alors que PHP lui-même est monothread, Laravel atteint le parallélisme en exécutant plusieurs processus (workers). Cette conception simple mais efficace permet à Laravel de gérer de lourdes charges de travail, même avec les limitations de PHP.
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!