Diese zweiteiligen Tutorial-Anfänger bei der Verwendung von Push-Warteschlangen mit Laravel für Hintergrundaufgaben, illustriert durch ein Foto-Upload und das Änderungsbeispiel. Die Größe des Änderns von Bildern ist zeitaufwändig; Dieser Ansatz verhindert die Verzögerungen von Benutzern, indem die Aufgabe abgeladen wird. Wir werden auch NGROK nutzen, um lokale Warteschlangen zu ermöglichen.
Der vollständige Quellcode ist auf GitHub verfügbar. Alternativ zum Testen auf einem Live -Server bereitgestellt.
Schlüsselkonzepte
Eine Warteschlange ist eine Jobpipeline. Jobs werden nacheinander in der Reihenfolge verarbeitet, die sie hinzugefügt haben. Im Gegensatz zu Pull -Warteschlangen benachrichtigen Sie die Warteschlangen, die Abonnenten proaktiv benachrichtigen, wenn ein Job fertig ist, und beseitigen Sie die Notwendigkeit einer ständigen Umfrage. Ironmq ist ein Dienst, der dieses Push-basierte Warteschlangensystem erleichtert. Beim Erstellen einer Push -Warteschlange definieren Sie eine Abonnenten -URL. Ironmq sendet Jobdaten an diese URL, wenn ein Job verfügbar ist.
Für einen tieferen Eintauchen in die Warteschlangen und Vergleiche verschiedener Lösungen finden Sie in [diesen Artikel] (link_to_article_here - Ersetzen Sie durch den tatsächlichen Link, falls verfügbar).
Setup und Installation
In diesem Abschnitt wird die Installation von Laravel, seine Abhängigkeiten, Erstellen eines Iron.io -Kontos und Konfigurieren von Ngrok.
laravel
und führen Sie composer create-project laravel/laravel --prefer-dist
aus. Greifen Sie auf Ihre Laravel -Installation unter laravel
zuzugreifen. php artisan serve
http://localhost:8000
. app/config/database.php
php artisan migrate:install
app/views/welcome.blade.php
"require": { "laravel/framework": "^9.0", // or your Laravel version "iron-io/iron_mq": "^1.4", "intervention/image": "^2.7" },
run composer update
. Konfigurieren Sie dann das Interventionsbildpaket in config/app.php
, indem Sie den Dienstanbieter und den Alias hinzufügen, wie in der Interventionsbilddokumentation dokumentiert.
ngrok
Für lokale Tests mit IronMQ verwenden Sie NGROK, um Ihren lokalen Server dem Internet auszusetzen.
./ngrok 8000
(oder der entsprechende Port, wenn Ihr Laravel -Server einen anderen verwendet). Beachten Sie die Weiterleitungs -URL (z. B. http://your-ngrok-url.ngrok.io
). Diese URL wird als Abonnenten -URL fungieren. ironmq
Erstellen Sie ein Iron.io -Konto und ein Projekt.
Erhalten Sie Ihre Projekt -ID und Ihr Token aus dem iio.io -Dashboard.
Konfigurieren Sie Ihre Laravel -Warteschlangeneinstellungen in config/queue.php
:
'iron' => [ 'driver' => 'iron', 'project' => env('IRON_PROJECT_ID'), 'token' => env('IRON_TOKEN'), 'queue' => 'laravel', ],
add IRON_PROJECT_ID
und IRON_TOKEN
zu Ihrer .env
Datei.
Erstellen Sie einen Push -Warteschlangen -Abonnent mit dem Handwerksbefehl:
php artisan queue:subscribe laravel http://your-ngrok-url.ngrok.io/queue/receive
Ersetzen Sie http://your-ngrok-url.ngrok.io
durch Ihre NGROK -Weiterleitungs -URL.
Fügen Sie die folgende Route zu routes/web.php
:
Route::post('queue/receive', function () { return Queue::marshal(); });
Schlussfolgerung (Teil 1)
Dieser Teil deckt den Einrichtung und die Installation der erforderlichen Komponenten ab. Teil zwei wird sich auf den Aufbau der Anwendung und die Implementierung des Image -Größenauftrags konzentrieren.
häufig gestellte Fragen (FAQs) (Dieser Abschnitt bleibt weitgehend unverändert, da die Informationen noch relevant sind.)
(Der vorhandene FAQ-Abschnitt ist gut geschrieben und genau; keine Änderungen sind erforderlich.)
Das obige ist der detaillierte Inhalt vonIronmq und Laravel: Setup. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!