Heim  >  Artikel  >  PHP-Framework  >  Wie verwende ich Supervisor zum Verwalten der ThinkPHP6-Warteschlange?

Wie verwende ich Supervisor zum Verwalten der ThinkPHP6-Warteschlange?

WBOY
WBOYOriginal
2023-06-12 08:51:091460Durchsuche

Bei der kontinuierlichen Weiterentwicklung von Webanwendungen müssen wir eine große Anzahl von Aufgaben bewältigen, um die Stabilität und Verfügbarkeit der Anwendung aufrechtzuerhalten. Die Verwendung eines Warteschlangensystems ist eine Lösung. ThinkPHP6 bietet ein integriertes Warteschlangensystem zur Verwaltung von Aufgaben. Die Bearbeitung einer großen Anzahl von Aufgaben erfordert jedoch eine bessere Warteschlangenverwaltung, die mit Supervisor erreicht werden kann.

In diesem Artikel erfahren Sie, wie Sie Supervisor zum Verwalten von ThinkPHP6-Warteschlangen verwenden. Zuvor müssen wir einige grundlegende Konzepte verstehen:

  1. Warteschlangensystem
    Das Warteschlangensystem ist eine Möglichkeit, Aufgaben asynchron zu verarbeiten, indem Aufgaben zur Warteschlange hinzugefügt werden, anstatt sie direkt zu verarbeiten. Sobald eine Aufgabe zur Warteschlange hinzugefügt wird, kann sie verschiedenen Mitarbeitern zugewiesen werden, um eine langfristige Blockierung der Webanwendung zu vermeiden. Das Warteschlangensystem kann auch einige komplexe Aufgabenvorgänge ausführen.
  2. Aufgabe
    In einem Warteschlangensystem ist eine Aufgabe die Arbeit, die ausgeführt werden muss. Sie können den Code, der asynchron ausgeführt werden muss, in eine Aufgabe packen und die Aufgabe dann zur Warteschlange hinzufügen, um auf die nachfolgende Verarbeitung zu warten. Wir können die Warteschlangenkomponente im PHP-Framework oder eine Bibliothek eines Drittanbieters verwenden, um Aufgaben zu verwalten, wie z. B. die Warteschlangenkomponente von Laravel oder Beanstalkd usw.
  3. Supervisor
    Supervisor ist ein Prozesskontrollsystem, das einen oder mehrere Prozesse, einschließlich Warteschlangenarbeiter, überwachen und steuern kann. Der Vorgesetzte kann das Warteschlangensystem stabiler und langlebiger machen. Mit Supervisor können Worker automatisch neu gestartet werden, wenn Aufgaben fehlschlagen, und es kann auch sichergestellt werden, dass Aufgaben in der Warteschlange nach dem Neustart der Webanwendung weiter verarbeitet werden können.

Nachdem wir diese Grundkonzepte verstanden haben, stellen wir vor, wie man Supervisor zum Verwalten von ThinkPHP6-Warteschlangen verwendet.

Schritt 1: Supervisor installieren

Um Supervisor für die Warteschlangenverwaltung zu verwenden, müssen wir zuerst Supervisor installieren. Auf einem Ubuntu-System können Sie den folgenden Befehl zur Installation verwenden:

sudo apt-get install supervisor

Auf einem CentOS-System können Sie den folgenden Befehl zur Installation verwenden:

sudo yum install supervisor

Nach Abschluss der Installation können Sie Supervisor mit dem folgenden Befehl starten:

sudo systemctl start supervisor

Gleichzeitig müssen wir auch ein Profil erstellen /etc/supervisor/conf.d/中创建一个新的配置文件来管理队列工作者。我们可以在该目录中创建一个任意名称的文件,如laravel-worker.conf. Als Nächstes erfahren Sie, wie Sie diese Datei bearbeiten.

Schritt 2: Bearbeiten Sie die Supervisor-Konfigurationsdatei.

Bearbeiten Sie die Supervisor-Konfigurationsdatei und fügen Sie Mitarbeiter zur Supervisor-Beobachtungsliste hinzu. Wir können den folgenden Befehl verwenden, um die gerade erstellte Konfigurationsdatei zu bearbeiten:

sudo nano /etc/supervisor/conf.d/laravel-worker.conf

Fügen Sie der Datei die folgende Konfiguration hinzu:

[program:laravel-worker]
process_name=%(program_name)s_%(process_num)02d
directory=/var/www/laravel #修改为你的项目目录
command=php /var/www/laravel/artisan queue:work
autostart=true
autorestart=true
user=www-data #修改为你的Web服务器运行用户
numprocs=8 #工作者数量,此处建议设置为CPU核心数2-4倍
redirect_stderr=true
stdout_logfile=/var/www/laravel/storage/logs/worker.log #修改为你的日志文件位置

Nachdem wir die obige Konfiguration zur Datei hinzugefügt haben, können wir den folgenden Befehl verwenden, um die Supervisor-Konfigurationsdatei neu zu laden :

sudo supervisorctl reread
sudo supervisorctl update

Auf diese Weise kann der Supervisor unsere Warteschlangenarbeiter starten und verwalten. Wir können den folgenden Befehl verwenden, um alle vom Supervisor gestarteten Prozesse anzuzeigen:

sudo supervisorctl status

Schritt 3: Testen Sie die Warteschlangenaufgabe

Jetzt haben wir den Warteschlangenarbeiter erfolgreich mit Supervisor gestartet. Als nächstes müssen wir die Warteschlangenaufgabe testen. Stellen Sie zunächst sicher, dass Ihre Warteschlange in Ihrer Anwendung konfiguriert ist.

Fügen Sie irgendwo eine Testaufgabe hinzu und lassen Sie die Warteschlange beginnen. Erstellen Sie beispielsweise eine E-Mail-Versandaufgabe:

<?php

namespace appqueue;

use thinkqueueJob;

class SendEmail
{
    public $user;

    public function __construct($user)
    {
        $this->user = $user;
    }

    public function fire(Job $job, $data)
    {
        //发送Email的代码
        if (Math.random() < 0.5) {
            // 处理失败
            $job->release(5);// 5秒后重试
        } else {
            // 成功处理
            $job->delete();
        }
    }
}

Fügen Sie eine Methode im Controller hinzu und fügen Sie die Aufgabe hinzu:

<?php

namespace appcontroller;

use thinkController;
use thinkqueueQueue;

class Email extends Controller
{
    public function index()
    {
        $user = ['email' => 'test@test.com', 'name' => 'test'];
        $job = new ppqueueSendEmail($user);
        app('queue')->push($job);
    }
}

Auf diese Weise können wir Supervisor erfolgreich zur Verwaltung der ThinkPHP6-Warteschlange verwenden. Wenn Sie mehr über das Warteschlangensystem erfahren möchten, können Sie die offizielle Dokumentation lesen. Ich hoffe, dieser Artikel kann Ihnen helfen, Ihre Webanwendung erfolgreich auszuführen!

Das obige ist der detaillierte Inhalt vonWie verwende ich Supervisor zum Verwalten der ThinkPHP6-Warteschlange?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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