Heim Backend-Entwicklung PHP-Tutorial Verwendung von Redis zur Implementierung verteilter geplanter Aufgaben in PHP

Verwendung von Redis zur Implementierung verteilter geplanter Aufgaben in PHP

May 15, 2023 pm 02:01 PM
php redis 分布式

Redis ist eine leistungsstarke In-Memory-Datenbank, die die Vorteile schneller Lese- und Schreibgeschwindigkeiten bietet, ein gewisses Maß an Persistenz unterstützt und umfangreiche Datentypen bietet. Redis wird häufig in Szenarien wie Caching, Nachrichtenwarteschlangen und Echtzeit-Rankings verwendet. Während der Entwicklung müssen wir manchmal verteilte geplante Aufgaben implementieren, z. B. das Senden von E-Mails, das Bereinigen temporärer Dateien, das Aktualisieren des Caches usw. In diesem Artikel wird erläutert, wie Sie mit Redis verteilte geplante Aufgaben implementieren.

1. Von Redis unterstützte Datentypen

Zu den von Redis unterstützten Datentypen gehören: String, Hash, List, Set und Ordered Set. Bei der Implementierung verteilter geplanter Aufgaben konzentrieren wir uns hauptsächlich auf zwei Datentypen: geordnete Mengen und Listen.

  1. Ordered set#
Ordered set ist ein von Redis bereitgestellter Datentyp, der einer Hash-Tabelle ähnelt und Schlüsselwerte speichern kann , aber Werte (auch Scores genannt) können wiederholt werden, und jedem Wert ist ein Score zugeordnet, der zum Sortieren verwendet wird. Die Elemente in einer geordneten Menge werden nach Punktzahl von klein nach groß sortiert.

Wenn wir geordnete Mengen verwenden, um verteilte geplante Aufgaben zu implementieren, können wir die Ausführungszeit der Aufgabe als Punktzahl und den Aufgabeninhalt als Wert verwenden und jede Aufgabe in einer geordneten Menge speichern.

    List
List ist ein von Redis bereitgestellter Datentyp. Sie können Elemente hinzufügen und löschen. Redis bietet eine umfangreiche Liste von Befehlen, wie zum Beispiel: lpush, rpush, lpop, rpop usw.

Wenn wir eine Liste zum Implementieren verteilter geplanter Aufgaben verwenden, können wir den Aufgabeninhalt in der Liste speichern und den Befehl lpop verwenden, um die Aufgabe zur Ausführung abzurufen.

2. Schritte zur Implementierung verteilter Timing-Aufgaben

Die Implementierung verteilter Timing-Aufgaben kann grob in die folgenden Schritte unterteilt werden:

#🎜🎜 #Hinzufügen Ordnen Sie die Aufgabe der geordneten Menge zu und legen Sie die Ausführungszeit der Aufgabe als Punktzahl fest.
  1. Starten Sie einen Hintergrundprozess, um die Aufgaben in der geordneten Sammlung zu scannen, festzustellen, ob die Aufgabe ausgeführt werden muss, und die auszuführenden Aufgaben zur Aufgabenliste hinzuzufügen.
  2. Starten Sie mehrere Worker-Prozesse und fügen Sie Aufgaben zur Ausführung aus der Aufgabenliste hinzu.
  3. Nach Abschluss der Ausführung wird die Aufgabe aus dem geordneten Satz gelöscht.
  4. Aufgaben zu einem geordneten Satz hinzufügen
  5. Verwenden Sie den folgenden Befehl, um Aufgaben zu einem geordneten Satz hinzuzufügen:

ZADD-Aufgaben mit Zeitstempelinhalt

Unter diesen sind Aufgaben der Name der geordneten Sammlung, Zeitstempel die Ausführungszeit der Aufgabe (Unix-Zeitstempel) und Inhalt der Inhalt der Aufgabe.

Um beispielsweise eine Aufgabe „E-Mail senden“ zur geordneten Sammlung hinzuzufügen, nachdem die Ausführungszeit 10 Minuten beträgt, können Sie den folgenden Befehl verwenden:

ZADD Aufgaben $ (Datum - d „+10 Minuten“ +%s) „E-Mail senden“

Aufgaben im geordneten Satz scannen
  1. Hintergrund starten Prozess, verwenden Sie den folgenden Befehl, um alle Aufgaben, die ausgeführt werden müssen, aus dem geordneten Satz abzurufen:

ZRANGEBYSCORE task -inf $(date +%s) WITHSCORES

where -inf bedeutet, dass der Mindestwert im Sequenzsatz $(date +%s) den Unix-Zeitstempel der aktuellen Zeit darstellt.

Der obige Befehl gibt eine Liste mit Ergebnissen zurück, zum Beispiel:

1) „temporäre Dateien löschen“

2) „1626387489“

# 🎜🎜# Darunter ist „temporäre Dateien löschen“ der Aufgabeninhalt und „1626387489“ die Ausführungszeit der Aufgabe.

Nachdem Sie alle Aufgaben erhalten haben, die ausgeführt werden müssen, fügen Sie diese Aufgaben zur Aufgabenliste hinzu.

Aufgaben ausführen

  1. Starten Sie mehrere Worker-Prozesse und rufen Sie Aufgaben aus der Aufgabenliste zur Ausführung auf. Nach der Ausführung wird die Aufgabe aus der geordneten Menge entfernt.
Verwenden Sie den folgenden Befehl, um eine Aufgabe aus der Liste zu entfernen und auszuführen:

lpop task

wobei Aufgaben der Name der Liste ist.

Löschen Sie die Aufgabe aus dem geordneten Satz

  1. Nachdem die Aufgabe ausgeführt wurde, verwenden Sie den folgenden Befehl, um die Aufgabe aus dem geordneten Satz zu löschen:
ZREM-Aufgabeninhalt

Unter diesen ist Aufgaben der Name der geordneten Sammlung und Inhalt der Inhalt der Aufgabe.

3. Code-Implementierung

Im Folgenden verwenden wir PHP, um die oben genannten Schritte zu implementieren.

Aufgaben zu einem geordneten Satz hinzufügen

  1. Verwenden Sie den folgenden Code, um Aufgaben zu einem geordneten Satz hinzuzufügen:
  2. $redis = new Redis();
    $redis->connect('127.0.0.1', 6379);
    
    // 添加任务到有序集合
    $timestamp = strtotime("+10 minutes");
    $redis->zAdd('tasks', $timestamp, 'send email');
    Nach dem Login kopieren
    #🎜🎜 #
Scannen Sie die Aufgaben im geordneten Satz

    Verwenden Sie den folgenden Code, um die Aufgaben im geordneten Satz zu scannen und die Aufgaben, die ausgeführt werden müssen, zur Aufgabenliste hinzuzufügen:
  1. while(true) {
        // 扫描有序集合中的任务
        $scoreTasks = $redis->zRangeByScore('tasks', '-inf', time(), array('withscores' => true));
        foreach($scoreTasks as $task => $score) {
            // 将需要执行的任务添加到任务列表中
            $redis->lpush('task_list', $task);
            // 将任务从有序集合中删除
            $redis->zRem('tasks', $task);
        }
        // 每隔5秒扫描一次
        sleep(5);
    }
    Nach dem Login kopieren
Aufgaben ausführen

    Verwenden Sie den folgenden Code, um mehrere Worker-Prozesse zu starten und Aufgaben aus der Aufgabenliste zur Ausführung zu entfernen: #🎜🎜 #
    $redis = new Redis();
    $redis->connect('127.0.0.1', 6379);
    
    for($i=0; $i<10; $i++) {
        // 启动10个Worker进程
        $pid = pcntl_fork();
        if($pid == -1) {
            echo 'fork error!' . PHP_EOL;
            exit;
        } else if($pid == 0) {
            // 子进程中获取任务列表中的任务并执行
            while(true) {
                // 从列表中弹出一条任务
                $task = $redis->rpop('task_list');
                if(empty($task)) {
                    continue;
                }
                // 执行任务
                mail('user@example.com', 'Task', $task);
            }
        }
    }
    Nach dem Login kopieren
  1. 4. Zusammenfassung
Die oben genannten Schritte und Codeimplementierungen für die Verwendung von Redis zur Implementierung verteilter geplanter Aufgaben. Durch die Verwendung von Redis können Sie problemlos eine verteilte Aufgabenplanung implementieren und die gleichzeitigen Verarbeitungsfunktionen und die Ausführungseffizienz von Aufgaben verbessern. In tatsächlichen Anwendungen müssen wir den Code entsprechend der tatsächlichen Situation optimieren, z. B. durch die Verwendung von Sperren, um einen sich gegenseitig ausschließenden Zugriff auf die Aufgabenliste durchzuführen, durch die Verwendung von Timern, um Aufgaben regelmäßig abzurufen usw.

Das obige ist der detaillierte Inhalt vonVerwendung von Redis zur Implementierung verteilter geplanter Aufgaben in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So erstellen Sie den Redis -Clustermodus So erstellen Sie den Redis -Clustermodus Apr 10, 2025 pm 10:15 PM

Der Redis -Cluster -Modus bietet Redis -Instanzen durch Sharding, die Skalierbarkeit und Verfügbarkeit verbessert. Die Bauschritte sind wie folgt: Erstellen Sie ungerade Redis -Instanzen mit verschiedenen Ports; Erstellen Sie 3 Sentinel -Instanzen, Monitor -Redis -Instanzen und Failover; Konfigurieren von Sentinel -Konfigurationsdateien, Informationen zur Überwachung von Redis -Instanzinformationen und Failover -Einstellungen hinzufügen. Konfigurieren von Redis -Instanzkonfigurationsdateien, aktivieren Sie den Cluster -Modus und geben Sie den Cluster -Informationsdateipfad an. Erstellen Sie die Datei nodes.conf, die Informationen zu jeder Redis -Instanz enthält. Starten Sie den Cluster, führen Sie den Befehl erstellen aus, um einen Cluster zu erstellen und die Anzahl der Replikate anzugeben. Melden Sie sich im Cluster an, um den Befehl cluster info auszuführen, um den Clusterstatus zu überprüfen. machen

PHP vs. Python: Verständnis der Unterschiede PHP vs. Python: Verständnis der Unterschiede Apr 11, 2025 am 12:15 AM

PHP und Python haben jeweils ihre eigenen Vorteile, und die Wahl sollte auf Projektanforderungen beruhen. 1.PHP eignet sich für die Webentwicklung mit einfacher Syntax und hoher Ausführungseffizienz. 2. Python eignet sich für Datenwissenschaft und maschinelles Lernen mit präziser Syntax und reichhaltigen Bibliotheken.

Die Zukunft von PHP: Anpassungen und Innovationen Die Zukunft von PHP: Anpassungen und Innovationen Apr 11, 2025 am 12:01 AM

Die Zukunft von PHP wird erreicht, indem sich an neue Technologietrends angepasst und innovative Funktionen eingeführt werden: 1) Anpassung an Cloud Computing, Containerisierung und Microservice -Architekturen, Unterstützung von Docker und Kubernetes; 2) Einführung von JIT -Compilern und Aufzählungsarten zur Verbesserung der Leistung und der Datenverarbeitungseffizienz; 3) die Leistung kontinuierlich optimieren und Best Practices fördern.

PHP: Stirbt es oder passt es sich einfach an? PHP: Stirbt es oder passt es sich einfach an? Apr 11, 2025 am 12:13 AM

PHP stirbt nicht, sondern sich ständig anpasst und weiterentwickelt. 1) PHP hat seit 1994 mehreren Versionen für die Version unterzogen, um sich an neue Technologietrends anzupassen. 2) Es wird derzeit in E-Commerce, Content-Management-Systemen und anderen Bereichen häufig verwendet. 3) PHP8 führt den JIT -Compiler und andere Funktionen ein, um die Leistung und Modernisierung zu verbessern. 4) Verwenden Sie Opcache und befolgen Sie die PSR-12-Standards, um die Leistung und die Codequalität zu optimieren.

So implementieren Sie die zugrunde liegenden Redis So implementieren Sie die zugrunde liegenden Redis Apr 10, 2025 pm 07:21 PM

Redis verwendet Hash -Tabellen, um Daten zu speichern und unterstützt Datenstrukturen wie Zeichenfolgen, Listen, Hash -Tabellen, Sammlungen und geordnete Sammlungen. Ernähren sich weiterhin über Daten über Snapshots (RDB) und appendiert Mechanismen nur Schreibmechanismen. Redis verwendet die Master-Slave-Replikation, um die Datenverfügbarkeit zu verbessern. Redis verwendet eine Ereignisschleife mit einer Thread, um Verbindungen und Befehle zu verarbeiten, um die Datenatomizität und Konsistenz zu gewährleisten. Redis legt die Ablaufzeit für den Schlüssel fest und verwendet den faulen Löschmechanismus, um den Ablaufschlüssel zu löschen.

So sehen Sie alle Schlüssel in Redis So sehen Sie alle Schlüssel in Redis Apr 10, 2025 pm 07:15 PM

Um alle Schlüssel in Redis anzuzeigen, gibt es drei Möglichkeiten: Verwenden Sie den Befehl keys, um alle Schlüssel zurückzugeben, die dem angegebenen Muster übereinstimmen. Verwenden Sie den Befehl scan, um über die Schlüssel zu iterieren und eine Reihe von Schlüssel zurückzugeben. Verwenden Sie den Befehl Info, um die Gesamtzahl der Schlüssel zu erhalten.

H5: Tools, Frameworks und Best Practices H5: Tools, Frameworks und Best Practices Apr 11, 2025 am 12:11 AM

Zu den Tools und Frameworks, die in der H5 -Entwicklung gemeistert werden müssen, gehören Vue.js, React und WebPack. 1.Vue.js eignet sich zum Erstellen von Benutzeroberflächen und unterstützt die Komponentenentwicklung. 2. Die Rendern des Seitenrenders über virtuelle DOM optimiert, geeignet für komplexe Anwendungen. 3.Webpack wird zur Modulverpackung und zur Optimierung der Ressourcenlast verwendet.

Was tun, wenn Redis-Server nicht gefunden werden kann Was tun, wenn Redis-Server nicht gefunden werden kann Apr 10, 2025 pm 06:54 PM

Schritte zur Lösung des Problems, das Redis-Server nicht finden kann: Überprüfen Sie die Installation, um sicherzustellen, dass Redis korrekt installiert ist. Setzen Sie die Umgebungsvariablen Redis_host und Redis_port; Starten Sie den Redis-Server Redis-Server; Überprüfen Sie, ob der Server Redis-Cli Ping ausführt.

See all articles