Heim > Backend-Entwicklung > PHP-Tutorial > PHP ist eine Single-Threaded-Sprache. Wie verarbeitet Laravel Warteschlangenjobs asynchron?

PHP ist eine Single-Threaded-Sprache. Wie verarbeitet Laravel Warteschlangenjobs asynchron?

Linda Hamilton
Freigeben: 2024-12-01 07:24:18
Original
443 Leute haben es durchsucht

PHP is a Single-Threaded Language, So How Does Laravel Handle Queue Jobs Asynchronously?

PHP ist als Single-Threaded-Sprache bekannt, was bedeutet, dass es jeweils nur eine Aufgabe innerhalb eines einzelnen Prozesses ausführen kann. Allerdings bietet Laravel ein robustes Warteschlangensystem, um mehrere Aufgaben „asynchron“ zu bearbeiten. Wenn PHP Single-Threaded ist, wie erreicht Laravel diese Magie? Lassen Sie es uns in einfachen Worten aufschlüsseln.

Was ist ein PHP-Prozess?

Bevor wir uns in Warteschlangen stürzen, müssen wir verstehen, was ein PHP-Prozess ist.

Ein Prozess ist wie ein Arbeiter, der eingestellt wird, um eine Aufgabe zu erledigen. Wenn Sie ein PHP-Skript ausführen (z. B. php my_script.php), erstellt das Betriebssystem einen neuen Prozess. Dieser Prozess:

  • Lädt das PHP-Skript.
  • Führt den Code Schritt für Schritt aus.
  • Hört auf und „stirbt“, wenn die Aufgabe erledigt ist. Zum Beispiel:
echo "Hello World!";
Nach dem Login kopieren
Nach dem Login kopieren

Wenn Sie dieses Skript ausführen, startet PHP einen Prozess, zeigt „Hello World!“ an und dann endet der Prozess.

PHP in Webanwendungen

In Webanwendungen:

  • Ein Webserver (wie Apache oder Nginx) empfängt eine HTTP-Anfrage von einem Browser.
  • Der Server erstellt einen neuen PHP-Prozess, um die Anfrage zu verarbeiten.
  • PHP verarbeitet die Anfrage (z. B. das Abrufen von Daten aus einer Datenbank oder das Rendern einer Seite).
  • Der Vorgang endet, nachdem eine Antwort an den Browser gesendet wurde.
  • PHP-Prozesse sind kurzlebig. Sie bearbeiten jeweils eine Anfrage und hören dann auf. Dieses Design macht PHP für Webanwendungen einfach und effizient.

Was ist Single-Threaded?

PHP ist Single-Threaded, was bedeutet:

  • Ein PHP-Prozess kann jeweils nur eine Aufgabe bearbeiten.
  • Es werden nicht mehrere Aufgaben gleichzeitig im selben Prozess ausgeführt. Zum Beispiel:
echo "Task 1";
// Waits for Task 1 to finish before starting Task 2
echo "Task 2";
Nach dem Login kopieren

PHP führt zuerst Aufgabe 1 aus. Erst wenn es fertig ist, geht es zu Aufgabe 2. Dieses Verhalten unterscheidet sich von Sprachen wie JavaScript, wo Aufgaben parallel im selben Prozess ausgeführt werden können.

Wie geht Laravel dann mit Warteschlangen um?

Das Warteschlangensystem von Laravel ermöglicht es Ihnen, mehrere Aufgaben im Hintergrund auszuführen, ohne die Hauptanwendung zu blockieren. Zum Beispiel:

  • E-Mails senden.
  • Bild-Uploads werden verarbeitet.
  • Benachrichtigungen senden. Diese Aufgaben werden im Hintergrund ausgeführt, sodass Ihre Hauptanwendung schneller auf Benutzer reagieren kann.

Aber PHP kann immer nur eine Aufgabe gleichzeitig erledigen, oder? Wie lässt Laravel es asynchron erscheinen? Die Antwort liegt in den Mitarbeitern und mehreren Prozessen.

Was ist ein Arbeiter?

Ein Worker in Laravel ist ein PHP-Prozess mit langer Laufzeit, der auf Jobs in einer Warteschlange wartet und diese ausführt.

Wenn Sie den Befehl ausführen:

php artisan queue:work
Nach dem Login kopieren

Ein neuer PHP-Prozess (oder Worker) wird gestartet. Dieser Prozess:

  • Verbindet sich mit dem Warteschlangensystem (wie Redis oder einer Datenbank).
  • Wartet darauf, dass neue Jobs (Aufgaben) in der Warteschlange ankommen.
  • Nimmt Aufträge einzeln auf und bearbeitet sie. Beispiel: Stellen Sie sich vor, Sie hätten die Aufgabe, 1.000 E-Mails zu versenden: Die Hauptanwendung sendet 1.000 Jobs an die Warteschlange. Ein Arbeitsprozess nimmt einen Job auf, sendet die E-Mail und geht zum nächsten Job über.

Wie erreicht Laravel asynchrones Verhalten?

Laravel erreicht „asynchrones“ Verhalten, indem es mehrere Worker gleichzeitig ausführt. Jeder Worker ist ein separater PHP-Prozess.

So funktioniert es:
Wenn Sie php artisan queue:work ausführen, beginnt es mit einem Worker (einem PHP-Prozess).
Sie können mehrere Mitarbeiter starten, um Jobs parallel auf verschiedenen Registerkarten lokal und in der Produktion zu bearbeiten, indem Sie den Prozessmanager wie den Vorgesetzten verwenden.
Dadurch werden mehrere PHP-Prozesse gestartet. Jeder Mitarbeiter erledigt Aufgaben unabhängig voneinander, sodass es den Anschein erweckt, als würden Aufgaben gleichzeitig ausgeführt.

Was passiert, wenn ein Job in der Warteschlange steht?

Wenn Sie einen Job in Laravel in die Warteschlange stellen, geschieht Folgendes Schritt für Schritt:

  1. Arbeitsplatzschaffung: Der Auftrag (z. B. das Senden einer E-Mail) wird serialisiert (in ein speicherbares Format konvertiert) und dem Warteschlangen-Backend (wie Redis oder einer Datenbank) hinzugefügt.
  2. Arbeiter fragt die Warteschlange ab: Die Arbeiter prüfen ständig die Warteschlange auf neue Jobs. Wenn ein Job gefunden wird, übernimmt der Arbeiter ihn.
  3. Auftragsausführung: Der Worker deserialisiert den Job und führt seine handle()-Methode aus. Sobald der Auftrag erledigt ist, wird er als abgeschlossen markiert.
  4. Auftragsabschluss: Der Arbeiter entfernt den Job aus der Warteschlange.

Wenn der Job fehlschlägt, versucht Laravel ihn erneut oder verschiebt ihn in eine Liste „fehlgeschlagener Jobs“ (basierend auf Ihrer Konfiguration).

Beispielszenario: E-Mails versenden
Stellen Sie sich vor, Sie haben eine Laravel-Anwendung, bei der Benutzer ein Kontaktformular einreichen. Wenn das Formular abgeschickt wird:

  • Die Hauptanwendung verarbeitet das Formular und antwortet dem Benutzer sofort.
  • Anstatt die E-Mail sofort zu senden, wird die E-Mail-Versandaufgabe einer Warteschlange hinzugefügt.

Im Hintergrund:

  • Ein Mitarbeiter übernimmt den E-Mail-Versand.
  • Sendet die E-Mail.
  • Geht zum nächsten Job.
  • Auf diese Weise muss der Benutzer nicht auf den Versand der E-Mail warten, was die App schneller macht.

Wie arbeiten Arbeiter in der Produktion?

In der Produktion werden Laravel-Mitarbeiter durch Tools wie Supervisor verwaltet. Der Supervisor hält die Arbeiter rund um die Uhr am Laufen und startet sie neu, wenn sie abstürzen.

Supervisor-Konfigurationsbeispiel:

echo "Hello World!";
Nach dem Login kopieren
Nach dem Login kopieren

Befehl: Führt den Befehl queue:work aus.
numprocs=5: Startet 5 Worker (5 PHP-Prozesse), um Jobs abzuwickeln.

Ist es wirklich asynchron?

Technisch gesehen sind Laravel-Warteschlangen nicht asynchron in der Art und Weise, wie JavaScript oder Node.js Aufgaben verarbeiten. Stattdessen:

Jeder Mitarbeiter erledigt jeweils eine Aufgabe.
Mehrere Worker (Prozesse) sorgen für Parallelität und erwecken den Anschein einer asynchronen Ausführung.

Wichtige Punkte, die Sie sich merken sollten

  • PHP ist Single-Threaded, sodass ein einzelner PHP-Prozess jeweils eine Aufgabe erledigt.
  • Laravel verwendet Worker (lang laufende PHP-Prozesse), um Warteschlangenjobs zu verarbeiten.
  • Mehrere Worker können gleichzeitig ausgeführt werden, sodass Aufträge parallel verarbeitet werden können.
  • Warteschlangen-Backends (wie Redis) fungieren als Vermittler, um Jobs zu speichern, bis Arbeiter sie abholen.
  • Tools wie Supervisor stellen sicher, dass die Mitarbeiter kontinuierlich in der Produktion arbeiten.

Das Warteschlangensystem von Laravel ist eine intelligente Möglichkeit, Aufgaben im Hintergrund zu erledigen und so die Anwendungsleistung und das Benutzererlebnis zu verbessern. Während PHP selbst Single-Threaded ist, erreicht Laravel Parallelität durch die Ausführung mehrerer Prozesse (Worker). Dieses einfache, aber effektive Design ermöglicht es Laravel, hohe Arbeitslasten zu bewältigen, selbst mit den Einschränkungen von PHP.

Das obige ist der detaillierte Inhalt vonPHP ist eine Single-Threaded-Sprache. Wie verarbeitet Laravel Warteschlangenjobs asynchron?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage