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

Einführung in Redis-Befehle zum Stapellöschen

Freigeben: 2020-05-06 09:12:44
nach vorne
4416 Leute haben es durchsucht

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个]
Nach dem Login kopieren

[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
Nach dem Login kopieren

[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:*'
Nach dem Login kopieren

[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 dem Login kopieren

[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:*'
Nach dem Login kopieren

[Ergebnis]:

redis-cli -a youpassowrd -n 0 -p 6379 --scan --pattern "Volume:*" | xargs -L 5000 redis-cli -a youpassword -n 0 -p 6379 DEL
Nach dem Login kopieren

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!

Verwandte Etiketten:
Quelle:csdn.net
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage