Heim Datenbank Redis So entwickeln Sie verteilte Sperrfunktionen mit Redis und Java

So entwickeln Sie verteilte Sperrfunktionen mit Redis und Java

Sep 21, 2023 am 08:40 AM
java redis 分布式锁

So entwickeln Sie verteilte Sperrfunktionen mit Redis und Java

So verwenden Sie Redis und Java, um verteilte Sperrfunktionen zu entwickeln

  1. Einführung
    Verteilte Sperren sind ein Mechanismus, um sich gegenseitig ausschließenden Zugriff auf gemeinsam genutzte Ressourcen in einem verteilten System zu ermöglichen. Wenn mehrere Knoten gleichzeitig auf gemeinsam genutzte Ressourcen zugreifen, muss sichergestellt werden, dass nur ein Knoten zugreift und die anderen Knoten warten müssen. Redis ist eine häufig verwendete In-Memory-Datenbank mit hoher Leistung und hoher Zuverlässigkeit und eignet sich sehr gut für die Implementierung verteilter Sperren.
  2. Der Setnx-Befehl von Redis
    Der Setnx-Befehl von Redis kann zum Festlegen des Werts eines Schlüssels verwendet werden, der Einstellvorgang wird jedoch nur ausgeführt, wenn der Schlüssel nicht vorhanden ist. Mit dieser Funktion können verteilte Sperrenerfassungsvorgänge implementiert werden. Versuchen Sie zunächst mit dem Befehl setnx, einen Schlüssel mit einer Ablaufzeit festzulegen. Wenn die Einstellung erfolgreich ist, bedeutet dies, dass die Sperre erfolgreich erworben wurde.
  3. Java-Codebeispiel
    Das Folgende ist ein Beispielcode, der die Java-Sprache und Redis verwendet, um verteilte Sperren zu implementieren:
import redis.clients.jedis.Jedis;

public class DistributedLock {
    private static final String LOCK_KEY = "distributed_lock";
    private static final int LOCK_TIMEOUT = 3 * 1000; // 锁的超时时间,单位为毫秒
    
    private Jedis jedis;

    public DistributedLock(Jedis jedis) {
        this.jedis = jedis;
    }

    public boolean lock() {
        long start = System.currentTimeMillis();
        try {
            while (true) {
                String result = jedis.set(LOCK_KEY, "locked", "NX", "PX", LOCK_TIMEOUT);
                if ("OK".equals(result)) {
                    return true;
                } else {
                    // 进行重试
                    Thread.sleep(100);
                }
                long end = System.currentTimeMillis();
                if (end - start > LOCK_TIMEOUT) {
                    // 超时退出
                    return false;
                }
            }
        } catch (InterruptedException e) {
            Thread.currentThread().interrupt();
            return false;
        }
    }

    public void unlock() {
        jedis.del(LOCK_KEY);
    }
}
Nach dem Login kopieren
  1. Beispielbeschreibung
    Im obigen Beispielcode wird die Jedis-Bibliothek zum Betrieb von Redis verwendet. Zunächst wird eine Konstante LOCK_KEY als Schlüssel der verteilten Sperre definiert. Dieser Schlüssel muss unter allen Knoten eindeutig bleiben. Darüber hinaus wird eine LOCK_TIMEOUT-Konstante festgelegt, um das Sperrzeitlimit darzustellen. LOCK_KEY作为分布式锁的键,这个键在所有节点中必须保持唯一。另外,设置了一个LOCK_TIMEOUT常量来表示锁的超时时间。

lock方法中,首先获取当前时间作为开始时间,然后使用一个无限循环来尝试获取分布式锁。在循环中,使用Redis的set命令进行设置操作,设置键为LOCK_KEY,值为"locked",并且设置了NXPX选项,NX表示只有键不存在时才执行设置操作,PX表示设置键的过期时间为LOCK_TIMEOUT毫秒。

如果设置成功,则表示获取锁成功,方法返回true;否则继续进行重试,每次重试时会等待100毫秒。同时,还需要判断获取锁的时间是否超过了LOCK_TIMEOUT的值,如果超过则表示获取锁的等待时间已经过长,放弃获取锁,并返回false

unlock方法中,通过调用del

    In der lock-Methode wird zunächst die aktuelle Zeit als Startzeit ermittelt und dann mithilfe einer Endlosschleife versucht, die verteilte Sperre zu erhalten. Verwenden Sie in der Schleife den Befehl set von Redis, um den Einstellungsvorgang durchzuführen. Der Set-Schlüssel ist LOCK_KEY, der Wert ist „locked“ und NX und PX Option, NX bedeutet, dass der Einstellungsvorgang nur ausgeführt wird, wenn der Schlüssel nicht vorhanden ist, PX bedeutet, dass die Ablaufzeit des Satzes Der Schlüssel ist LOCK_TIMEOUT</ code>Millisekunden. <li><br>Wenn die Einstellung erfolgreich ist, bedeutet dies, dass die Sperre erfolgreich erworben wurde und die Methode <code>true zurückgibt. Andernfalls wird der erneute Versuch fortgesetzt und bei jedem erneuten Versuch 100 Millisekunden gewartet. Gleichzeitig muss auch festgestellt werden, ob die Zeit zum Erlangen der Sperre den Wert von LOCK_TIMEOUT überschreitet. Wenn dieser Wert überschritten wird, bedeutet dies, dass die Wartezeit zum Erlangen der Sperre zu lang war. Geben Sie den Erwerb der Sperre auf und geben Sie false zurück.
Löschen Sie in der Methode unlock den Schlüssel der verteilten Sperre, indem Sie den Befehl del aufrufen.

    Aufrufbeispiel
  1. Das Folgende ist ein Aufrufbeispiel mit dem Beispielcode:
  2. import redis.clients.jedis.Jedis;
    
    public class LockTest {
        public static void main(String[] args) {
            Jedis jedis = new Jedis("localhost");
            DistributedLock lock = new DistributedLock(jedis);
            try {
                if (lock.lock()) {
                    // 获取到分布式锁后执行需要保护的代码
                    System.out.println("获取到分布式锁");
                    // ... 执行需要保护的代码
                } else {
                    System.out.println("获取分布式锁失败");
                }
            } finally {
                lock.unlock();
            }
        }
    }
    Nach dem Login kopieren
    Im Aufrufbeispiel wird zuerst ein Jedis-Verbindungsobjekt erstellt, dann wird ein DistributedLock-Objekt erstellt und das Jedis-Verbindungsobjekt wird als übergeben ein Parameter. Versuchen Sie im Try-Finally-Block zunächst, die verteilte Sperre zu erhalten. Geben Sie bei Erfolg „erhaltene verteilte Sperre“ aus, führen Sie den zu schützenden Code aus und geben Sie dann die verteilte Sperre im Final-Block frei. 🎜🎜🎜Zusammenfassung🎜Durch die Verwendung von Redis und der Java-Entwicklung können wir die verteilte Sperrfunktion problemlos implementieren. Der Sperrerfassungsvorgang kann mit dem Redis-Befehl setnx implementiert werden, und der Java-Code kann den Redis-Befehl problemlos aufrufen und in eine verteilte Sperrklasse einkapseln. In tatsächlichen Anwendungen kann das Timeout der verteilten Sperre nach Bedarf angepasst werden, um sicherzustellen, dass die Wartezeit für den Erwerb der Sperre nicht zu lang wird, wodurch die Leistung und Parallelität des Systems verbessert werden. 🎜🎜

    Das obige ist der detaillierte Inhalt vonSo entwickeln Sie verteilte Sperrfunktionen mit Redis und Java. 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)

So erstellen Sie den Redis -Clustermodus So erstellen Sie den Redis -Clustermodus Apr 10, 2025 pm 10:15 PM

Der Redis -Cluster -Modus bietet Redis -Instanzen durch Sharding, die Skalierbarkeit und Verfügbarkeit verbessert. Die Bauschritte sind wie folgt: Erstellen Sie ungerade Redis -Instanzen mit verschiedenen Ports; Erstellen Sie 3 Sentinel -Instanzen, Monitor -Redis -Instanzen und Failover; Konfigurieren von Sentinel -Konfigurationsdateien, Informationen zur Überwachung von Redis -Instanzinformationen und Failover -Einstellungen hinzufügen. Konfigurieren von Redis -Instanzkonfigurationsdateien, aktivieren Sie den Cluster -Modus und geben Sie den Cluster -Informationsdateipfad an. Erstellen Sie die Datei nodes.conf, die Informationen zu jeder Redis -Instanz enthält. Starten Sie den Cluster, führen Sie den Befehl erstellen aus, um einen Cluster zu erstellen und die Anzahl der Replikate anzugeben. Melden Sie sich im Cluster an, um den Befehl cluster info auszuführen, um den Clusterstatus zu überprüfen. machen

PHP vs. Python: Verständnis der Unterschiede PHP vs. Python: Verständnis der Unterschiede Apr 11, 2025 am 12:15 AM

PHP und Python haben jeweils ihre eigenen Vorteile, und die Wahl sollte auf Projektanforderungen beruhen. 1.PHP eignet sich für die Webentwicklung mit einfacher Syntax und hoher Ausführungseffizienz. 2. Python eignet sich für Datenwissenschaft und maschinelles Lernen mit präziser Syntax und reichhaltigen Bibliotheken.

PHP: Eine Schlüsselsprache für die Webentwicklung PHP: Eine Schlüsselsprache für die Webentwicklung Apr 13, 2025 am 12:08 AM

PHP ist eine Skriptsprache, die auf der Serverseite weit verbreitet ist und insbesondere für die Webentwicklung geeignet ist. 1.PHP kann HTML einbetten, HTTP -Anforderungen und Antworten verarbeiten und eine Vielzahl von Datenbanken unterstützt. 2.PHP wird verwendet, um dynamische Webinhalte, Prozessformdaten, Zugriffsdatenbanken usw. mit starker Community -Unterstützung und Open -Source -Ressourcen zu generieren. 3. PHP ist eine interpretierte Sprache, und der Ausführungsprozess umfasst lexikalische Analyse, grammatikalische Analyse, Zusammenstellung und Ausführung. 4.PHP kann mit MySQL für erweiterte Anwendungen wie Benutzerregistrierungssysteme kombiniert werden. 5. Beim Debuggen von PHP können Sie Funktionen wie error_reporting () und var_dump () verwenden. 6. Optimieren Sie den PHP-Code, um Caching-Mechanismen zu verwenden, Datenbankabfragen zu optimieren und integrierte Funktionen zu verwenden. 7

So löschen Sie Redis -Daten So löschen Sie Redis -Daten Apr 10, 2025 pm 10:06 PM

So löschen Sie Redis -Daten: Verwenden Sie den Befehl Flushall, um alle Schlüsselwerte zu löschen. Verwenden Sie den Befehl flushdb, um den Schlüsselwert der aktuell ausgewählten Datenbank zu löschen. Verwenden Sie SELECT, um Datenbanken zu wechseln, und löschen Sie dann FlushDB, um mehrere Datenbanken zu löschen. Verwenden Sie den Befehl del, um einen bestimmten Schlüssel zu löschen. Verwenden Sie das Redis-Cli-Tool, um die Daten zu löschen.

Php gegen andere Sprachen: Ein Vergleich Php gegen andere Sprachen: Ein Vergleich Apr 13, 2025 am 12:19 AM

PHP eignet sich für die Webentwicklung, insbesondere für die schnelle Entwicklung und Verarbeitung dynamischer Inhalte, ist jedoch nicht gut in Anwendungen auf Datenwissenschaft und Unternehmensebene. Im Vergleich zu Python hat PHP mehr Vorteile in der Webentwicklung, ist aber nicht so gut wie Python im Bereich der Datenwissenschaft. Im Vergleich zu Java wird PHP in Anwendungen auf Unternehmensebene schlechter, ist jedoch flexibler in der Webentwicklung. Im Vergleich zu JavaScript ist PHP in der Back-End-Entwicklung präziser, ist jedoch in der Front-End-Entwicklung nicht so gut wie JavaScript.

So lesen Sie Redis -Warteschlange So lesen Sie Redis -Warteschlange Apr 10, 2025 pm 10:12 PM

Um eine Warteschlange aus Redis zu lesen, müssen Sie den Warteschlangenname erhalten, die Elemente mit dem Befehl LPOP lesen und die leere Warteschlange verarbeiten. Die spezifischen Schritte sind wie folgt: Holen Sie sich den Warteschlangenname: Nennen Sie ihn mit dem Präfix von "Warteschlange:" wie "Warteschlangen: My-Queue". Verwenden Sie den Befehl LPOP: Wischen Sie das Element aus dem Kopf der Warteschlange aus und geben Sie seinen Wert zurück, z. B. die LPOP-Warteschlange: my-queue. Verarbeitung leerer Warteschlangen: Wenn die Warteschlange leer ist, gibt LPOP NIL zurück, und Sie können überprüfen, ob die Warteschlange existiert, bevor Sie das Element lesen.

PHP: Die Grundlage vieler Websites PHP: Die Grundlage vieler Websites Apr 13, 2025 am 12:07 AM

Die Gründe, warum PHP für viele Websites der bevorzugte Technologie -Stack ist, umfassen die Benutzerfreundlichkeit, die starke Unterstützung der Community und die weit verbreitete Verwendung. 1) Einfach zu erlernen und zu bedienen, geeignet für Anfänger. 2) eine riesige Entwicklergemeinschaft und eine reichhaltige Ressourcen haben. 3) in WordPress, Drupal und anderen Plattformen häufig verwendet. 4) Integrieren Sie eng in Webserver, um die Entwicklung der Entwicklung zu vereinfachen.

PHP vs. Python: Kernmerkmale und Funktionen PHP vs. Python: Kernmerkmale und Funktionen Apr 13, 2025 am 12:16 AM

PHP und Python haben jeweils ihre eigenen Vorteile und eignen sich für verschiedene Szenarien. 1.PHP ist für die Webentwicklung geeignet und bietet integrierte Webserver und reichhaltige Funktionsbibliotheken. 2. Python eignet sich für Datenwissenschaft und maschinelles Lernen mit prägnanter Syntax und einer leistungsstarken Standardbibliothek. Bei der Auswahl sollte anhand der Projektanforderungen festgelegt werden.

See all articles