Heim Datenbank Redis So fügen Sie den Redis-Befehl hinzu

So fügen Sie den Redis-Befehl hinzu

Jun 20, 2020 pm 04:40 PM
redis Befehl

So fügen Sie den Redis-Befehl hinzu

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

So fügen Sie den Redis-Befehl hinzu

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!

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

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

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.

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ßer Artikel

Rimworld odyssey wie man fischt
1 Monate vor By Jack chen
Kann ich zwei Alipay -Konten haben?
1 Monate vor By 下次还敢
Anfängerleitfaden zu Rimworld: Odyssey
4 Wochen vor By Jack chen
Variabler PHP -Bereich erklärt
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)

Heiße Themen

PHP-Tutorial
1506
276
Redis: Ein Vergleich mit herkömmlichen Datenbankservern Redis: Ein Vergleich mit herkömmlichen Datenbankservern May 07, 2025 am 12:09 AM

Redis ist traditionellen Datenbanken in hoher Parallelitäts- und Latenz -Szenarien überlegen, ist jedoch nicht für komplexe Abfragen und Transaktionsverarbeitung geeignet. 1.Redis verwendet Speicherspeicher-, Schnelllese- und Schreibgeschwindigkeit, geeignet für Anforderungen an eine hohe Parallelität und niedrige Latenz. 2. Traditionelle Datenbanken basieren auf Festplatten, unterstützen komplexe Abfragen und Transaktionsverarbeitung und haben eine starke Datenkonsistenz und -dauer. 3.. Redis ist als Ergänzung oder Ersatz für herkömmliche Datenbanken geeignet, muss jedoch nach bestimmten Geschäftsbedürfnissen ausgewählt werden.

Wie begrenzte ich Benutzerressourcen in Linux? Wie konfiguriere ich Ulimit? Wie begrenzte ich Benutzerressourcen in Linux? Wie konfiguriere ich Ulimit? May 29, 2025 pm 11:09 PM

Linux -System beschränkt die Benutzerressourcen durch den Befehl ulimit, um eine übermäßige Verwendung von Ressourcen zu verhindern. 1.ulimit ist ein integrierter Shell-Befehl, mit dem die Anzahl der Dateideskriptoren (-n), die Speichergröße (-V), die Threadzahl (-U) usw. begrenzt werden kann, die in Soft Limit (aktueller effektiver Wert) und hartem Grenze (maximale Obergrenze) unterteilt sind. 2. Verwenden Sie den Befehl ulimit direkt zur vorübergehenden Änderung, wie z. B. Ulimit-N2048, ist jedoch nur für die aktuelle Sitzung gültig. 3. Für den dauerhaften Effekt müssen Sie /etc/security/limits.conf- und PAM -Konfigurationsdateien ändern und SessionRequiredpam_Limits.so hinzufügen. 4. Der SystemD -Dienst muss Lim in der Einheitsdatei einstellen

Ist Redis in erster Linie eine Datenbank? Ist Redis in erster Linie eine Datenbank? May 05, 2025 am 12:07 AM

Redis ist in erster Linie eine Datenbank, aber mehr als nur eine Datenbank. 1. Als Datenbank unterstützt Wiedererlangung die Persistenz und eignet sich für leistungsstarke Bedürfnisse. 2. Als Cache verbessert Redis die Reaktionsgeschwindigkeit der Anwendung. 3. Als Message Broker unterstützt Redis den Veröffentlichungs-Subscribe-Modus, der für die Echtzeitkommunikation geeignet ist.

Schritte und Beispiele zum Erstellen einer dynamischen PHP -Website mit Phpstudy Schritte und Beispiele zum Erstellen einer dynamischen PHP -Website mit Phpstudy May 16, 2025 pm 07:54 PM

Zu den Schritten zum Erstellen einer dynamischen PHP -Website mithilfe von Phpstudy gehören: 1. Installieren Sie Phpstudy und starten Sie den Dienst; 2. Konfigurieren Sie das Root -Verzeichnis der Website und die Datenbankverbindung. 3. Schreiben Sie PHP -Skripte, um dynamische Inhalte zu generieren. 4.. Debuggen und optimieren Sie die Website -Leistung. Durch diese Schritte können Sie eine voll funktionsfähige dynamische PHP -Website von Grund auf neu erstellen.

Redis: Jenseits SQL - Die NoSQL -Perspektive Redis: Jenseits SQL - Die NoSQL -Perspektive May 08, 2025 am 12:25 AM

Redis geht aufgrund seiner hohen Leistung und Flexibilität über die SQL -Datenbanken hinaus. 1) Redis erreicht extrem schnelle Lesen und Schreiben von Geschwindigkeit über Speicherspeicher. 2) Es unterstützt eine Vielzahl von Datenstrukturen wie Listen und Sammlungen, die für die komplexe Datenverarbeitung geeignet sind. 3) Einfach-Thread-Modell vereinfacht die Entwicklung, aber eine hohe Parallelität kann zu einem Engpass werden.

Laravel Page Cache -Richtlinie Laravel Page Cache -Richtlinie May 29, 2025 pm 09:15 PM

Die Seiten -Caching -Strategie von Laravel kann die Leistung der Website erheblich verbessern. 1) Verwenden Sie Cache -Helferfunktionen, um das Seiten zwischen Seiten zu implementieren, wie z. 2) Wählen Sie das entsprechende Cache -Backend wie Redis aus. 3) Achten Sie auf Probleme mit der Datenkonsistenz und Sie können feinkörnige Caches oder Event-Hörer verwenden, um den Cache zu löschen. 4) Die weitere Optimierung wird mit Routing -Cache-, Ansichts -Cache- und Cache -Tags kombiniert. Durch die rationale Anwendung dieser Strategien kann die Leistung der Website effektiv verbessert werden.

Wann sollte ich Redis anstelle einer herkömmlichen Datenbank verwenden? Wann sollte ich Redis anstelle einer herkömmlichen Datenbank verwenden? May 13, 2025 pm 04:01 PM

UsedisinSteadofatitionaldatabaseWenyourApplicationRequiresspeedandreal-Timedataprocessing, Suchasforcaching, SessionManagement, Orreal-Timalytics.Rectisexcelsin: 1) Caching, ReducingloadonPimarydatabase;

Redis Master-Slave-Replikationsfehler Fehlerbehebungsprozess Redis Master-Slave-Replikationsfehler Fehlerbehebungsprozess Jun 04, 2025 pm 08:51 PM

Zu den Schritten zur Fehlerbehebung und Reparatur von Redis-Master-Slave-Replikationsfehlern gehören: 1. Überprüfen Sie die Netzwerkverbindung und verwenden Sie Ping oder Telnet, um die Konnektivität zu testen; 2. Überprüfen Sie die Redis-Konfigurationsdatei, um sicherzustellen, dass die Replikation und die Wiederholungs-Timeout korrekt eingestellt sind. 3. Überprüfen Sie die Redis -Protokolldatei und finden Sie Fehlerinformationen. 4. Wenn es sich um ein Netzwerkproblem handelt, starten Sie das Netzwerkgerät neu oder wechseln Sie den alternativen Pfad. 5. Wenn es sich um ein Konfigurationsproblem handelt, ändern Sie die Konfigurationsdatei. 6. Wenn es sich um ein Problem mit der Datensynchronisierung handelt, verwenden Sie den Befehl slaveof, um die Daten neu zu synchronisieren.

See all articles