Redis ist aufgrund seiner hohen Leistung und einfachen Funktionen zum Standard-Cache für Internetunternehmen geworden. Manchmal möchten wir einige benutzerdefinierte Befehle hinzufügen, hauptsächlich in Szenarien, in denen Redis stark genutzt wird In Eilkaufszenarien muss die Transaktionalität mehrerer Redis-Befehle sichergestellt werden. Wenn keine gute Atomizitätsgarantie besteht, kann es leicht zu Dateninkonsistenzproblemen kommen.
Obwohl der offizielle Transaktionsplan bereitgestellt wird, kann der Transaktionsplan dies nicht bewältigen, wenn vor dem Fortfahren mit dem nächsten Schritt eine Beurteilung auf der Grundlage des Rückgabewerts eines bestimmten Befehls vorgenommen werden muss.
Heute beschreiben wir anhand eines praktischen Falls, wie man einen Redis-Befehl hinzufügt. Dieser Befehl wird hauptsächlich in Anti-Brushing-Szenarien verwendet:
Oft ist es notwendig, eine bestimmte IP oder ein zu sperren Wenn dieser Befehl für einen bestimmten Zeitraum nicht verwendet wird, lautet die Lösung wie folgt:
Zuerst incr und dann feststellen, ob es 1 ist. Wenn es 1 ist, legen Sie die Ablaufzeit fest. Es ist ersichtlich, dass der Schlüssel nicht abläuft, wenn der erste Client, der die Incr-Anfrage initiiert, bei hoher Parallelität auflegt.
Der heute zu schreibende Befehl wird verwendet, um diese Transaktion sicherzustellen. Die Serverseite stellt sicher, dass die Ablaufzeit festgelegt wird, wenn der Wert des Schlüssels 1 ist. Die Verwendung des Befehls
ist wie folgt:
incexpire key expireTime maxNum
key: der zu verarbeitende Schlüssel
expireTime: Ablaufzeit in Sekunden. Wenn Sie 10 schreiben, bedeutet dies dass der Schlüssel in 10 Sekunden abläuft. ;
maxNum: Gibt an, wie hoch der Wert sein wird, bis er nicht mehr erhöht wird. Wenn er auf 10 gesetzt ist, beträgt der zurückgegebene Maximalwert 11. Die Rückgabe von 11 bedeutet, dass dies der Fall ist wurde überschritten;
2. Schreiben Sie den Befehl
1. Laden Sie den Redis-Code herunter
Die in diesem Artikel verwendete Redis-Version ist
Laden Sie den Code herunter und wechseln Sie zum Zweig 3.2.11
git clone https://github.com/antirez/redis
2. Schreiben Sie zusätzlichen Befehlscode
1) Fügen Sie einen neuen Befehl zur redisCommandTable-Struktur in src/server.c
struct redisCommand redisCommandTable[] = {hinzu
redisCommandTable ist ein Array, jedes Element repräsentiert einen Redis-Befehl und das erste stellt einen Befehl dar. Das zweite ist die eigentliche Verarbeitungsfunktion und das dritte ist die Anzahl der Parameter. Die anderen werden nicht im Detail besprochen.
2) Fügen Sie eine Funktionsdeklaration in src/server.h hinzu:
void incrExpireCommand(client *c);
3) Fügen Sie dann eine Datei als ljh.c hinzu (benennen Sie sie selbst) und fügen Sie den folgenden Code hinzu:
#include "server.h"
4) Fügen Sie eine neue Datei ljh.o in src/Makefile hinzu
REDIS_SERVER_OBJ=adlist.o quicklist.o ae.o anet.o dict.o server.o sds.o zmalloc.o lzf_c.o lzf_d.o pqsort.o zipmap.o sha1.o ziplist.o release.o networking
Der Ausführungseffekt ist wie folgt
Wie Sie sehen können, Nachdem key1 auf 11 erhöht wurde, erhöht es sich nicht mehr und wird nach 10 Sekunden wieder 1.
Abschließend müssen wir uns noch fragen, ob es notwendig ist, Redis-Befehle in unser Szenario aufzunehmen. Bei Bedarf müssen wir die Verantwortlichkeiten zwischen den einzelnen Ebenen verstehen und nicht zulassen, dass Redis das Geschäft im Allgemeinen abwickelt Es heißt, dass die Middleware-Schicht im Allgemeinen relativ häufige Funktionen verarbeitet, je stabiler die untere Schicht sein sollte und je weniger Änderungen vorgenommen werden, desto normaler ist die Situation.
Weitere Informationen zu diesem Thema finden Sie in der Spalte Redis-Einführungs-Tutorial
Das obige ist der detaillierte Inhalt vonSo fügen Sie den Redis-Befehl hinzu. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!