Heim Java javaLernprogramm Was ist der Grund, warum der Rückgabewert leer ist, wenn die RedISTEMplate für die Stapelabfrage verwendet wird? Wie löst ich dieses Problem?

Was ist der Grund, warum der Rückgabewert leer ist, wenn die RedISTEMplate für die Stapelabfrage verwendet wird? Wie löst ich dieses Problem?

Apr 19, 2025 pm 05:48 PM
redis 键值对 red

Dieser Artikel analysiert den Grund, warum der Rückgabewert leer ist, wenn RedisTemplate von Spring Data Redis für die Batch -Abfrage verwendet wird, und entsprechende Lösungen. Bei Verwendung der executePipelined -Methode für den Batch GET -Betrieb ist der Rückgabewert leer, wenn das Ergebnis direkt in der Pipeline verarbeitet wird. Dies liegt daran, dass der Pipeline -Vorgang alle Befehle zwischenstrahlt und erst an den Redis -Server gesendet wird, wenn executePipelined aufgerufen wird, und die interne Verarbeitung kann nicht rechtzeitig zurückgegeben werden.

Frage Beschreibung:

In dem Artikel sind zwei Fehlerbeispiele angegeben, die beide versuchen, die Ergebnisse des GET -Befehls in executePipelined zu verarbeiten, was dazu führt, dass die endgültige zurückgegebene Liste nur null ist.

Problemanalyse und Lösungen:

Der Kern des Problems liegt in den asynchronen Eigenschaften von Pipeline -Operationen. Der korrekte Ansatz sollte durchgeführt werden, nachdem executePipelined Methode das Ergebnis zurückgegeben und dann einheitlich behandelt wird. Die erste in diesem Artikel bereitgestellte Methode des Deserializes innerhalb einer Schleife, die die Effizienz von Pipeline -Operationen zerstört. Obwohl die zweite Methode SessionCallback verwendet, führt sie dennoch eine Ergebnisverarbeitung innerhalb der Pipeline durch.

Verbesserte Lösungen:

Im Artikel wird eine verbesserte batchGetList -Methode bereitgestellt, in der der Rückgabewert von executePipelined korrekt verwendet wird:

 öffentlich<t> Liste<t> BatchgetList (Sammlung<string> Schlüssel) {
    if (collectionUtil.isempty (keys)) {
        NeuarrayList  () zurückgeben;
    }

    Liste<object> Ergebnisse = redistemplate.executepipelined ((Redisconnection -Verbindung) -> {
        Redisserializer<string> Keyserializer = (Redisserializer<string> ) redistemplate.getkeyserializer ();
        für (Stringschlüssel: Schlüssel) {
            Connection.get (KeySerializer.Serialize (Schlüssel));
        }
        null zurückkehren;
    });

    // Externe Verarbeitungsergebnisse in den Pipeline -Rückgabeergebnissen ausführen. Stream ()
                  .MAP (Ergebnis -> (t) redistemplate.getValueSerializer (). Deserialize ((Byte []) Ergebnis)))
                  .Collect (sammel.tolist ());
}</string></string></object></string></t></t>
Nach dem Login kopieren

Diese Methode prüft zuerst, ob keys leer sind, und verwendet dann executePipelined um Stapel GET -Operationen durchzuführen. Der Schlüssel ist, dass nach Abschluss der Pipeline -Ausführung Stream -API verwendet wird, um results zu durchqueren und jedes Ergebnis mithilfe redisTemplate.getValueSerializer().deserialize Dies vermeidet die falsche Praxis der Verarbeitungsergebnisse in der Pipeline und stellt sicher, dass die Daten in Redis ordnungsgemäß abgerufen werden. Es ist zu beachten, dass diese Methode davon ausgeht, dass alle Schlüsselwertpaare denselben Deserializer verwenden. Wenn es mehrere Datentypen gibt, muss es gemäß den tatsächlichen Bedingungen angepasst werden.

Was ist der Grund, warum der Rückgabewert leer ist, wenn die RedISTEMplate für die Stapelabfrage verwendet wird? Wie löst ich dieses Problem?

Das obige ist der detaillierte Inhalt vonWas ist der Grund, warum der Rückgabewert leer ist, wenn die RedISTEMplate für die Stapelabfrage verwendet wird? Wie löst ich dieses Problem?. 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

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.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

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ß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)

Welche Schritte sind erforderlich, um CentOs in HDFs zu konfigurieren Welche Schritte sind erforderlich, um CentOs in HDFs zu konfigurieren Apr 14, 2025 pm 06:42 PM

Das Erstellen eines Hadoop -verteilten Dateisystems (HDFS) auf einem CentOS -System erfordert mehrere Schritte. Dieser Artikel enthält einen kurzen Konfigurationshandbuch. 1. Bereiten Sie sich auf die Installation von JDK in der frühen Stufe vor: Installieren Sie JavadevelopmentKit (JDK) auf allen Knoten, und die Version muss mit Hadoop kompatibel sein. Das Installationspaket kann von der offiziellen Oracle -Website heruntergeladen werden. Konfiguration der Umgebungsvariablen: Bearbeiten /etc /Profildatei, setzen Sie Java- und Hadoop -Umgebungsvariablen, damit das System den Installationspfad von JDK und Hadoop ermittelt. 2. Sicherheitskonfiguration: SSH-Kennwortfreie Anmeldung zum Generieren von SSH-Schlüssel: Verwenden Sie den Befehl ssh-keygen auf jedem Knoten

Wie man JSON in Notepad formatiert Wie man JSON in Notepad formatiert Apr 16, 2025 pm 07:48 PM

Verwenden Sie das JSON-Viewer-Plug-In in Notepad, um JSON-Dateien einfach zu formatieren: Öffnen Sie eine JSON-Datei. Installieren und aktivieren Sie das JSON-Viewer-Plug-In. Gehen Sie zu "Plugins" & gt; "JSON Viewer" & gt; "Format JSON". Passen Sie die Einstellungen für Einklehung, Verzweigung und Sortier an. Wenden Sie Formatierung an, um die Lesbarkeit und das Verständnis zu verbessern und so die Verarbeitung und Bearbeitung von JSON -Daten zu vereinfachen.

So installieren Sie Redis in CentOS7 So installieren Sie Redis in CentOS7 Apr 14, 2025 pm 08:21 PM

Laden Sie das Quellcodepaket von der offiziellen Redis -Quelle herunter, um es zu kompilieren und zu installieren, um die neueste und stabile Version zu gewährleisten, und kann auf personalisierte Weise angepasst werden. Die spezifischen Schritte sind wie folgt: Aktualisieren Sie die Liste der Softwarepakets und erstellen

So konfigurieren Sie langsame Abfragebogin in CentOS Redis So konfigurieren Sie langsame Abfragebogin in CentOS Redis Apr 14, 2025 pm 04:54 PM

Aktivieren Sie Redis langsame Abfrageprotokolle im CentOS -System, um die Leistungsdiagnoseeffizienz zu verbessern. In den folgenden Schritten führen Sie die Konfiguration durch: Schritt 1: Suchen und bearbeiten Sie die Redis -Konfigurationsdatei zuerst und suchen Sie die Redis -Konfigurationsdatei, die sich normalerweise in /etc/redis/redis.conf befindet. Öffnen Sie die Konfigurationsdatei mit dem folgenden Befehl: Sudovi/etc/redis/redis.conf Schritt 2: Passen Sie die Langsame-Abfrage-Protokollparameter in der Konfigurationsdatei an, suchen Sie die folgenden Parameter: #Slow Query-Schwellenwert (MS) Slow-Log-Slow-Than10000 #Maximum der Einträge für langsame Query-Log-Logog-Logog-Len-Len-Len

Welche Dateien müssen Sie in HDFS -Konfigurations -CentOS ändern? Welche Dateien müssen Sie in HDFS -Konfigurations -CentOS ändern? Apr 14, 2025 pm 07:27 PM

Beim Konfigurieren von Hadoop-Distributed Dateisystem (HDFS) auf CentOS müssen die folgenden Schlüsselkonfigurationsdateien geändert werden: Core-Site.xml: Fs.DefaultFs: Gibt die Standarddateisystemadresse von HDFs an, wie z. B. HDFS: // localhost: 9000. Hadoop.tmp.dir: Gibt das Speicherverzeichnis für Hadoop -temporäre Dateien an. Hadoop.proxyuser.root.hosts und Hadoop.proxyuser.ro

Tipps zur Verwendung von HDFS -Dateisystem auf CentOS Tipps zur Verwendung von HDFS -Dateisystem auf CentOS Apr 14, 2025 pm 07:30 PM

Das Installations-, Konfigurations- und Optimierungshandbuch für das HDFS -Dateisystem unter CentOS -System In diesem Artikel wird die Installation, Konfiguration und Optimierung von Hadoop Distributed Dateisystem (HDFS) auf CentOS -System geleitet. HDFS -Installation und Konfiguration Java -Umgebung Installation: Stellen Sie zunächst sicher, dass die entsprechende Java -Umgebung installiert ist. Bearbeiten/etc/Profildatei, Folgendes hinzufügen und /usr/lib/java-1.8.0/jdk1.8.0_144 mit Ihrem tatsächlichen Java-Installationspfad: exportjava_home =/usr/lib/java-1.8.0/jdk1.8.0_144144141441444 = $ java-1.8.0/Jdk1.8.0_144444 = $ Java-1. Java-1 $ Java-1.8.8.0_14444, ersetzen

Verwenden von DICR/YII2-Google zur Integration von Google API in YII2 Verwenden von DICR/YII2-Google zur Integration von Google API in YII2 Apr 18, 2025 am 11:54 AM

VPROCESSERAZRABOTKIVEB-ENTLEGEN, мненеришшшо & лносsprechen, LeavallySumballanceFriablanceFaumdoptomatification, čtookazalovnetakprosto, Kakaožidal.Posenesko

Wie verwendet ich die Redis -Cache -Lösung, um die Anforderungen der Produktranking -Liste effizient zu erkennen? Wie verwendet ich die Redis -Cache -Lösung, um die Anforderungen der Produktranking -Liste effizient zu erkennen? Apr 19, 2025 pm 11:36 PM

Wie erkennt die Redis -Caching -Lösung die Anforderungen der Produktranking -Liste? Während des Entwicklungsprozesses müssen wir uns häufig mit den Anforderungen der Ranglisten befassen, z. B. das Anzeigen eines ...

See all articles