Heim >Datenbank >Redis >Einführung in Redis-Befehle zum Stapellöschen

Einführung in Redis-Befehle zum Stapellöschen

尚
nach vorne
2020-05-06 09:12:444397Durchsuche

Einführung in Redis-Befehle zum Stapellöschen

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!

Stellungnahme:
Dieser Artikel ist reproduziert unter:csdn.net. Bei Verstößen wenden Sie sich bitte an admin@php.cn löschen