Redis implementiert Batch-Löschung:
1. Greifen Sie auf das Redis-Stammverzeichnis cd /usr/local/redis-2.8.19 zu
2 in redis: redis-cli -h 127.0.0.1 -p 6379 (wobei 127.0.0.1 als IP-Adresse des Servers geschrieben werden kann und 6379 die Portnummer ist)
3. Alle Schlüsselwerte anzeigen :keys *
4. Löschen Sie den Wert des angegebenen Index: del key
5. Löschen Sie die Daten des gesamten Redis-Servers:lushall
6 in der aktuellen Bibliothek: Flushdb
[Erste Methode]:
Das Folgende ist eine Stapellöschung aller Redis-Daten, die mit „key_“ beginnen und deren Anzahl 100 ist
redis-cli -h (IP地址) -p 6379 (端口号:6379) KEYS key_* | xargs redis-cli (-h (IP地址) -p 6379 (端口号:6379)) del =>[执行后返回的结果影响数量]:(integer) 100[数量100个]
[Spezifische Verwendung der DEL-Funktion im obigen Befehl]:
DEL-Taste [Taste ...]
Löschen Sie eine oder mehrere angegebene Tasten.
Nicht vorhandene Schlüssel werden ignoriert.
Zeitliche Komplexität:
O(N), N ist die Anzahl der gelöschten Schlüssel.
Löschen Sie einen einzelnen Schlüssel vom Typ Zeichenfolge. Die zeitliche Komplexität beträgt O (1).
Löschen Sie einen einzelnen Listen-, Satz-, geordneten Satz- oder Hash-Tabellentypschlüssel. Die Zeitkomplexität beträgt O (M), M ist die Anzahl der Elemente in der obigen Datenstruktur.
Rückgabewert:
Die Anzahl der gelöschten Schlüssel.
[Beispiel]:
# 删除单个 key redis> SET name huangz OK redis> DEL name (integer) 1 # 删除一个不存在的 key redis> EXISTS phone (integer) 0 redis> DEL phone # 失败,没有 key 被删除 (integer) 0 # 同时删除多个 key redis> SET name "redis" OK redis> SET type "key-value store" OK redis> SET website "redis.com" OK redis> DEL name type website (integer) 3
[Zweite Methode]:
Nachteile der ersten Methode: Ein solcher Nachteil erfordert, dass jedes Mal eine Verbindung hergestellt werden muss, was akzeptabel ist wenn die Menge groß ist, aber die Effizienz ist nicht gut, wenn die Menge groß ist.
Mit dem integrierten Lua-Interpreter können Sie den EVAL-Befehl verwenden, um Lua-Skripte zu verarbeiten:
redis-cli -h(IP地址) -p 6379(端口号:6379) --EVAL "return redis.call('del', unpack(redis.call('keys', ARGV[1])))" 0 'Volume:*'
[Hinweis]: Diese Verarbeitungsmethode führt jedoch zu Problemen beim Entpacken der Lua-Funktion, wenn Das Volumen ist groß. , wird ein Fehler gemeldet
''' (error) ERR Error running script (call to f_e177a091510d969af3b388ee986dbe6658df6b57): @user_script:1: user_script:1: too many results to unpack '''
[Nach der Optimierung der zweiten Methode]:
[Hinweis]: Definieren Sie zunächst ein Array-Schlüssel, in dem alle Musterübereinstimmungsschlüssel gespeichert werden endet mit der Taste „Volume:“ und dann einer for-Schleife, die jedes Mal 5000 Schlüssel verarbeitet, d Der Betrieb von KEYS ist online verboten!
Redis ist Single-Threaded. Wenn das Volumen groß ist, werden die Schlüssel durchlaufen, was zu Blockaden führt und andere Clients keine Verbindung herstellen können!
[Dritte Methode]:
Der Scan-Befehl wird seit Redis2.8 unterstützt. Der Mustervergleich kann die folgende Form annehmen, um eine große Anzahl von Schlüsseln stapelweise zu löschen
redis-cli -h(IP地址) -p 6379(端口号:6379) --EVAL "local keys = redis.call('keys', ARGV[1]) for i=1,#keys,5000 do redis.call('del', unpack(keys, i, math.min(i+4999, #keys))) end return #keys" 0 'Volume:*'
[Ergebnis]:
redis-cli -a youpassowrd -n 0 -p 6379 --scan --pattern "Volume:*" | xargs -L 5000 redis-cli -a youpassword -n 0 -p 6379 DEL
Weitere Redis-Kenntnisse finden Sie in der Spalte
Redis-Einführungs-Tutorial.
Das obige ist der detaillierte Inhalt vonEinführung in Redis-Befehle zum Stapellöschen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!