Inhaltsverzeichnis
Redis Publish/Subscribe-Anwendung
SUBSCRIBE命令的实现
PSUBSCRIBE命令的实现
Heim Datenbank Redis Beispielanalyse für das Redis-Publish/Subscribe-Modell

Beispielanalyse für das Redis-Publish/Subscribe-Modell

May 27, 2023 pm 09:29 PM
redis

Redis Publish/Subscribe-Anwendung

Publish and Subscribe (Pub/Sub) ist ein Nachrichtenkommunikationsmodell. Der Hauptzweck besteht darin, die Kopplung zwischen Nachrichtenherausgebern und Nachrichtenabonnenten zu entkoppeln. Dies ähnelt dem Beobachter im Entwurfsmuster sind relativ ähnlich. Pub/Sub löst nicht nur die direkte Kopplung von Herausgebern und Abonnenten auf Codeebene, sondern auch die Kopplung der beiden bei der physischen Bereitstellung. Als Pub/Sub-Server übernimmt Redis eine Nachrichtenweiterleitungsfunktion zwischen Abonnenten und Herausgebern. Abonnenten können den Redis-Server für die Nachrichtentypen abonnieren, an denen sie interessiert sind, indem sie die Befehle subscribe und psubscribe verwenden. Redis nennt den Nachrichtentyp einen Kanal. Wenn der Herausgeber über den Veröffentlichungsbefehl eine bestimmte Art von Nachricht an den Redis-Server sendet. Alle Clients, die diesen Nachrichtentyp abonnieren, erhalten diese Nachricht. Die Nachrichtenzustellung erfolgt hier viele-zu-viele. Ein Client kann mehrere Kanäle abonnieren und Nachrichten an mehrere Kanäle senden.

Beginnen wir mit den Grundbefehlen:

PSUBSCRIBE pattern [pattern ...]              #订阅一个或多个符合给定模式的频道;PUBSUB subcommand [argument [argument ...]]   #查看订阅与发布系统状态;PUBLISH channel message                       #将信息发送到指定的频道;PUNSUBSCRIBE [pattern [pattern ...]]          #退订所有给定模式的频道;SUBSCRIBE channel [channel ...]               #订阅给定的一个或多个频道的信息;UNSUBSCRIBE [channel [channel ...]]           #指退订给定的频道;
Nach dem Login kopieren

Wie Sie dem Redis-Handbuch entnehmen können, gibt es im Modus „Veröffentlichen und Abonnieren“ tatsächlich nur 6 Befehle,

ABONNIEREN

Abonnieren Sie die angegebenen Informationen für einen oder mehrere Kanäle.

SUBSCRIBE channel [channel ...]
Nach dem Login kopieren

Nach der offiziellen Erklärung oben zu urteilen, ist das Gameplay ein bisschen so, wie wir im wirklichen Leben Radio hören. Was machen wir, wenn wir Radio hören wollen? Es muss sich um FM handeln, um gute Programme anzuhören. Um sie zu abonnieren, muss ich zum Beispiel zwei Clients anführen. wie folgt:

root@localhost:~ # redis-cli -p 6379127.0.0.1:6379> SUBSCRIBE msg
Reading messages... (press Ctrl-C to quit)
1) "subscribe"2) "msg"3) (integer) 1

root@localhost:~ # redis-cli -p 6379127.0.0.1:6379> SUBSCRIBE msg
Reading messages... (press Ctrl-C to quit)
1) "subscribe"2) "msg"3) (integer) 1
Nach dem Login kopieren

SUBSCRIBE kann auch mehrere Kanäle abonnieren, sodass die empfangenen Informationen möglicherweise von mehreren Kanälen stammen.

VERÖFFENTLICHEN

Bislang überwachen diese beiden Abonnenten den Nachrichtenkanal. Wenn es Neuigkeiten vom Nachrichtenkanal gibt, werden diese auf jeden Fall per Abonnement empfangen diesen Befehl.

Senden Sie eine Informationsnachricht an den angegebenen Kanal.

PUBLISH channel message
Nach dem Login kopieren

Die folgende Demonstration:

Beispielanalyse für das Redis-Publish/Subscribe-Modell

Sehen Sie, nachdem Publish eine Nachricht auf dem MSG-Kanal gesendet hat, wird sie von Subscribe überwacht und dann separat ausgedruckt. Okay, bisher ist das einfachste Veröffentlichungsmodell . Ist es nicht ganz einfach? Eigentlich? ? ? So einfach ist das, aber manchmal haben wir immer noch ein Bedürfnis, das heißt, kann ich den Schlüssel unscharf zuordnen? Es ist beispielsweise erforderlich, alle Kanäle mit dem Präfix China zu abonnieren. Wenn dies möglich ist, wäre das wirklich großartig. . . Wenn ich antworten würde, wäre es sicherlich so, dass das mächtige Redis das auf jeden Fall kann, es stellt den Befehl PSUBSCRIBE bereit.

PSUBSCRIBE

Abonnieren Sie einen oder mehrere Kanäle, die einem bestimmten Muster entsprechen. Jedes Muster verwendet als Matcher. Es stimmt beispielsweise mit allen damit beginnenden Kanälen überein (it.news, it.blog, it.tweets). usw.), news.* entspricht allen Kanälen, die mit news beginnen (news.it, news.global.today usw.) und so weiter.

PSUBSCRIBE pattern [pattern ...]
Nach dem Login kopieren

Nachdem Sie die obige Erklärung gesehen haben, denken Sie vielleicht: Ist das nicht nur ein regulärer Matching? . . Als nächstes werde ich alle Kanäle mit „china“ als Präfix abonnieren, denn das Präfix „P“ steht für „Pattern“, oder? .

Beispielanalyse für das Redis-Publish/Subscribe-Modell

PSUBSCRIBE kann mehrere Parameter empfangen, um verschiedene Muster abzugleichen. Nachdem Sie ein kleines Beispiel gelesen haben, sollten Sie ein Verständnis für die Pub/Sub-Funktion haben. Beachten Sie, dass eine Verbindung in den Abonnementmodus wechselt, wenn sie den Abonnementkanal „subscribe“ oder „psubscribe“ durchläuft. In diesem Modus können keine anderen Befehle gesendet werden, außer das Abonnieren zusätzlicher Kanäle oder das Verlassen des Abonnementmodus mit dem Befehl „unsubscribe“ oder „punsubscribe“. Verwenden Sie außerdem den Befehl psubscribe, um mehrere Wildcard-Kanäle zu abonnieren. Wenn eine Nachricht mit mehreren Kanalmustern übereinstimmt, wird dieselbe Nachricht mehrmals empfangen.

Obwohl die Pub/Sub-Implementierung von Redis nur 150 Codezeilen erfordert, sind ihre Funktionen möglicherweise nicht vollständig genug. Es gibt nicht viel Unterstützung in Bezug auf Sicherheit, Authentifizierung und Zuverlässigkeit.

Redis-Publish/Subscribe-Mechanismus

Wenn ein Client über den PUBLISH-Befehl Informationen an Abonnenten sendet, nennen wir den Client einen Herausgeber.

Wenn ein Client den Befehl SUBSCRIBE oder PSUBSCRIBE verwendet, um Informationen zu empfangen, nennen wir den Client einen Abonnenten.

Um die Beziehung zwischen Herausgeber und Abonnenten zu entkoppeln, verwendet Redis den Kanal als Vermittler zwischen den beiden – der Herausgeber veröffentlicht Informationen direkt an den Kanal und der Kanal ist dafür verantwortlich, dass die Nachricht an den entsprechenden Abonnenten gesendet wird Abonnenten haben keine gegenseitige Beziehung und wissen nicht, dass sie voneinander existieren:

Beispielanalyse für das Redis-Publish/Subscribe-Modell

知道了发布和订阅的机制之后,接下来就可以开始研究具体的实现了,我们从Redis的订阅命令开始说起。

SUBSCRIBE命令的实现

前面说到,Redis将所有接受和发送信息的任务交给channel来进行,而所有channel的信息就储存在redisServer这个结构中:

struct redisServer {
  // 省略 ...
  dict *pubsub_channels; // Map channels to list of subscribed clients
  // 省略 ...
};
Nach dem Login kopieren

pubsub_channels是一个字典,字典的键就是一个个channel,而字典的值则是一个链表,链表中保存了所有订阅这个channel的客户端。

举个例子,如果在一个 redisServer 实例中,有一个叫做 news 的频道,这个频道同时被client_123 和 client_456 两个客户端订阅,那么这个 redisServer 结构看起来应该是这样子: Beispielanalyse für das Redis-Publish/Subscribe-Modell

可以看出,实现SUBSCRIBE命令的关键,就是将客户端添加到给定channel的订阅链表中。

PSUBSCRIBE命令的实现

除了直接订阅给定channel外,还可以使用PSUBSCRIBE订阅一个模式(pattern),订阅一个模式等同于订阅所有匹配这个模式的channel 。

和redisServer.pubsub_channels属性类似,redisServer.pubsub_patterns属性用于保存所有被订阅的模式,和pubsub_channels不同的是, pubsub_patterns是一个链表(而不是字典):

struct redisServer {
  // 省略 ...
  list *pubsub_patterns; // A list of pubsub_patterns
  // 省略 ...
};
Nach dem Login kopieren

pubsub_patterns 的每一个节点都是一个 pubsubPattern 结构的实例,它保存了被订阅的模式,以及订阅这个模式的客户客户端:

typedef struct pubsubPattern {
  redisClient *client;
  robj *pattern;
} pubsubPattern;
Nach dem Login kopieren

举个例子,假设在一个 redisServer 实例中,有一个叫做 news.* 的模式同时被客户端client_789 和 client_999 订阅,那么这个 redisServer 结构看起来应该是这样子: Beispielanalyse für das Redis-Publish/Subscribe-Modell

现在可以知道,实现PSUBSCRIBE命令的关键,就是将客户端和订阅的模式添加到redisServer.pubsub_patterns当中。

Das obige ist der detaillierte Inhalt vonBeispielanalyse für das Redis-Publish/Subscribe-Modell. 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

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

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

So löschen Sie Redis -Daten So löschen Sie Redis -Daten Apr 10, 2025 pm 10:06 PM

So löschen Sie Redis -Daten: Verwenden Sie den Befehl Flushall, um alle Schlüsselwerte zu löschen. Verwenden Sie den Befehl flushdb, um den Schlüsselwert der aktuell ausgewählten Datenbank zu löschen. Verwenden Sie SELECT, um Datenbanken zu wechseln, und löschen Sie dann FlushDB, um mehrere Datenbanken zu löschen. Verwenden Sie den Befehl del, um einen bestimmten Schlüssel zu löschen. Verwenden Sie das Redis-Cli-Tool, um die Daten zu löschen.

So lesen Sie Redis -Warteschlange So lesen Sie Redis -Warteschlange Apr 10, 2025 pm 10:12 PM

Um eine Warteschlange aus Redis zu lesen, müssen Sie den Warteschlangenname erhalten, die Elemente mit dem Befehl LPOP lesen und die leere Warteschlange verarbeiten. Die spezifischen Schritte sind wie folgt: Holen Sie sich den Warteschlangenname: Nennen Sie ihn mit dem Präfix von "Warteschlange:" wie "Warteschlangen: My-Queue". Verwenden Sie den Befehl LPOP: Wischen Sie das Element aus dem Kopf der Warteschlange aus und geben Sie seinen Wert zurück, z. B. die LPOP-Warteschlange: my-queue. Verarbeitung leerer Warteschlangen: Wenn die Warteschlange leer ist, gibt LPOP NIL zurück, und Sie können überprüfen, ob die Warteschlange existiert, bevor Sie das Element lesen.

So verwenden Sie den Befehl Redis So verwenden Sie den Befehl Redis Apr 10, 2025 pm 08:45 PM

Die Verwendung der REDIS -Anweisung erfordert die folgenden Schritte: Öffnen Sie den Redis -Client. Geben Sie den Befehl ein (Verbschlüsselwert). Bietet die erforderlichen Parameter (variiert von der Anweisung bis zur Anweisung). Drücken Sie die Eingabetaste, um den Befehl auszuführen. Redis gibt eine Antwort zurück, die das Ergebnis der Operation anzeigt (normalerweise in Ordnung oder -err).

So verwenden Sie Redis Lock So verwenden Sie Redis Lock Apr 10, 2025 pm 08:39 PM

Um die Operationen zu sperren, muss die Sperre durch den Befehl setNX erfasst werden und dann den Befehl Ablauf verwenden, um die Ablaufzeit festzulegen. Die spezifischen Schritte sind: (1) Verwenden Sie den Befehl setNX, um zu versuchen, ein Schlüsselwertpaar festzulegen; (2) Verwenden Sie den Befehl Ablauf, um die Ablaufzeit für die Sperre festzulegen. (3) Verwenden Sie den Befehl Del, um die Sperre zu löschen, wenn die Sperre nicht mehr benötigt wird.

So lesen Sie den Quellcode von Redis So lesen Sie den Quellcode von Redis Apr 10, 2025 pm 08:27 PM

Der beste Weg, um Redis -Quellcode zu verstehen, besteht darin, Schritt für Schritt zu gehen: Machen Sie sich mit den Grundlagen von Redis vertraut. Wählen Sie ein bestimmtes Modul oder eine bestimmte Funktion als Ausgangspunkt. Beginnen Sie mit dem Einstiegspunkt des Moduls oder der Funktion und sehen Sie sich die Codezeile nach Zeile an. Zeigen Sie den Code über die Funktionsaufrufkette an. Kennen Sie die von Redis verwendeten Datenstrukturen. Identifizieren Sie den von Redis verwendeten Algorithmus.

So verwenden Sie die Befehlszeile der Redis So verwenden Sie die Befehlszeile der Redis Apr 10, 2025 pm 10:18 PM

Verwenden Sie das Redis-Befehlszeilen-Tool (REDIS-CLI), um Redis in folgenden Schritten zu verwalten und zu betreiben: Stellen Sie die Adresse und den Port an, um die Adresse und den Port zu stellen. Senden Sie Befehle mit dem Befehlsnamen und den Parametern an den Server. Verwenden Sie den Befehl Hilfe, um Hilfeinformationen für einen bestimmten Befehl anzuzeigen. Verwenden Sie den Befehl zum Beenden, um das Befehlszeilenwerkzeug zu beenden.

So lösen Sie Datenverlust mit Redis So lösen Sie Datenverlust mit Redis Apr 10, 2025 pm 08:24 PM

Zu den Ursachen für Datenverluste gehören Speicherausfälle, Stromausfälle, menschliche Fehler und Hardwarefehler. Die Lösungen sind: 1. Speichern Sie Daten auf Festplatten mit RDB oder AOF Persistenz; 2. Kopieren Sie auf mehrere Server, um eine hohe Verfügbarkeit zu erhalten. 3. Ha mit Redis Sentinel oder Redis Cluster; 4. Erstellen Sie Schnappschüsse, um Daten zu sichern. 5. Implementieren Sie Best Practices wie Persistenz, Replikation, Schnappschüsse, Überwachung und Sicherheitsmaßnahmen.

See all articles