Maison Java javaDidacticiel Comment utiliser les verrous distribués en Java pour réaliser la synchronisation des systèmes distribués ?

Comment utiliser les verrous distribués en Java pour réaliser la synchronisation des systèmes distribués ?

Aug 03, 2023 am 08:43 AM
分布式锁 java分布式锁 分布式系统同步

Comment utiliser les verrous distribués en Java pour réaliser la synchronisation des systèmes distribués ?

Introduction :
Dans un système distribué, des conflits de données et des problèmes de concurrence peuvent survenir lorsque plusieurs nœuds accèdent à des ressources partagées en même temps. Afin de garantir la cohérence des données, nous devons utiliser des verrous distribués pour réaliser la synchronisation des systèmes distribués. Java propose diverses façons d'implémenter des verrous distribués. Cet article présentera les méthodes d'implémentation de verrous distribués basées sur ZooKeeper et Redis, avec des exemples de code.

1. Implémentation de verrouillage distribué basée sur ZooKeeper
ZooKeeper est un service de coordination distribué, qui fournit un mécanisme de verrouillage distribué pour résoudre les problèmes de synchronisation dans les systèmes distribués. Voici un exemple de code qui utilise ZooKeeper pour implémenter des verrous distribués :

import org.apache.zookeeper.*;

import java.io.IOException;
import java.util.Collections;
import java.util.List;

public class ZooKeeperDistributedLock implements Watcher {
    private ZooKeeper zooKeeper;
    private String lockPath;
    private String currentPath;
    private String waitPath;

    public ZooKeeperDistributedLock(String connectString, int sessionTimeout, String lockPath) throws IOException {
        zooKeeper = new ZooKeeper(connectString, sessionTimeout, this);
        this.lockPath = lockPath;
    }

    public void lock() throws KeeperException, InterruptedException {
        if (tryLock()) {
            return;
        }

        while (true) {
            List<String> children = zooKeeper.getChildren(lockPath, false);
            Collections.sort(children);

            int index = children.indexOf(currentPath.substring(lockPath.length() + 1));
            if (index == 0) {
                return;
            }

            waitPath = lockPath + "/" + children.get(index - 1);
            zooKeeper.exists(waitPath, true);
            synchronized (this) {
                wait();
            }
        }
    }

    public void unlock() throws KeeperException, InterruptedException {
        zooKeeper.delete(currentPath, -1);
    }

    private boolean tryLock() throws KeeperException, InterruptedException {
        currentPath = zooKeeper.create(lockPath + "/lock", new byte[0], ZooDefs.Ids.OPEN_ACL_UNSAFE, CreateMode.EPHEMERAL_SEQUENTIAL);
        List<String> children = zooKeeper.getChildren(lockPath, false);
        Collections.sort(children);
        if (currentPath.endsWith(children.get(0))) {
            return true;
        }
        String currentPathName = currentPath.substring(lockPath.length() + 1);
        int index = children.indexOf(currentPathName);
        if (index < 0) {
            throw new IllegalStateException("Node " + currentPathName + " no longer exists.");
        } else {
            waitPath = lockPath + "/" + children.get(index - 1);
            zooKeeper.exists(waitPath, true);
            synchronized (this) {
                wait();
            }
            return false;
        }
    }

    @Override
    public void process(WatchedEvent event) {
        if (waitPath != null && event.getType() == Event.EventType.NodeDeleted && event.getPath().equals(waitPath)) {
            synchronized (this) {
                notifyAll();
            }
        }
    }
}
Copier après la connexion

2. Implémentation de verrous distribués basée sur Redis
Redis est un système de stockage clé-valeur hautes performances qui fournit certaines opérations atomiques pour implémenter des verrous distribués. Voici un exemple de code permettant d'utiliser Redis pour implémenter des verrous distribués :

import redis.clients.jedis.Jedis;

public class RedisDistributedLock {
    private Jedis jedis;
    private String lockKey;
    private String requestId;

    public RedisDistributedLock(String host, int port, String password, String lockKey, String requestId) {
        jedis = new Jedis(host, port);
        jedis.auth(password);
        this.lockKey = lockKey;
        this.requestId = requestId;
    }

    public boolean lock(long expireTimeMillis) {
        String result = jedis.set(lockKey, requestId, "NX", "PX", expireTimeMillis);
        return "OK".equals(result);
    }

    public boolean unlock() {
        Long result = (Long) jedis.eval(
                "if redis.call('get', KEYS[1]) == ARGV[1] then " +
                "return redis.call('del', KEYS[1]) " +
                "else " +
                "return 0 " +
                "end",
                1,
                lockKey,
                requestId);
        return result != null && result == 1;
    }
}
Copier après la connexion

Conclusion :
Cet article présente deux méthodes d'utilisation des verrous distribués en Java pour réaliser la synchronisation des systèmes distribués : basée sur ZooKeeper et Redis. Que vous utilisiez ZooKeeper ou Redis, vous pouvez réaliser efficacement la synchronisation des systèmes distribués et garantir la cohérence des données. Dans les projets réels, le choix d'une solution de verrouillage distribué appropriée doit être pondéré en fonction des besoins spécifiques et des exigences de performances. J'espère que cet article vous sera utile, merci d'avoir lu !

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Comment déverrouiller tout dans Myrise
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Serrure distribuée : 5 cases, de l'entrée à l'enterrement Serrure distribuée : 5 cases, de l'entrée à l'enterrement Aug 24, 2023 pm 02:48 PM

Ce que je veux partager avec vous aujourd'hui, ce sont les verrous distribués. Cet article utilise cinq cas, diagrammes, analyses de code source, etc. Les verrous courants tels que synchronisé et Lock sont tous implémentés sur la base d'une seule JVM. Que devons-nous faire dans un scénario distribué ? A cette époque, des verrous distribués sont apparus.

Utilisation de ZooKeeper pour le traitement des verrous distribués dans le développement d'API Java Utilisation de ZooKeeper pour le traitement des verrous distribués dans le développement d'API Java Jun 17, 2023 pm 10:36 PM

À mesure que les applications modernes continuent d’évoluer et que le besoin de haute disponibilité et de simultanéité augmente, les architectures de systèmes distribués deviennent de plus en plus courantes. Dans un système distribué, plusieurs processus ou nœuds s'exécutent en même temps et accomplissent des tâches ensemble, et la synchronisation entre les processus devient particulièrement importante. Étant donné que de nombreux nœuds d'un environnement distribué peuvent accéder simultanément à des ressources partagées, la manière de gérer les problèmes de concurrence et de synchronisation est devenue une tâche importante dans un système distribué. À cet égard, ZooKeeper est devenu une solution très populaire. ZooKee

La solution reine parmi les serrures distribuées - Redisson La solution reine parmi les serrures distribuées - Redisson Aug 24, 2023 pm 03:31 PM

Si vous avez déjà utilisé Redis, vous obtiendrez deux fois le résultat avec la moitié de l'effort en utilisant Redisson, qui constitue le moyen le plus simple et le plus pratique d'utiliser Redis. Le but de Redisson est de promouvoir la séparation des préoccupations des utilisateurs (Separation of Concern) de Redis, afin que les utilisateurs puissent se concentrer davantage sur le traitement de la logique métier.

Comparaison d'Etcd dans l'implémentation Redis des verrous distribués Comparaison d'Etcd dans l'implémentation Redis des verrous distribués Jun 20, 2023 pm 05:51 PM

Avec la popularisation progressive des systèmes distribués, les verrous distribués sont devenus un moyen important pour garantir la stabilité du système et la cohérence des données. En tant que base de données à mémoire distribuée hautes performances, Redis est naturellement devenue l'une des implémentations importantes de verrous distribués. Cependant, ces dernières années, Etcd a reçu de plus en plus d’attention en tant que solution émergente de cohérence distribuée. Cet article discutera des similitudes et des différences entre l'implémentation des verrous distribués par Redis et Etcd sous des aspects tels que les principes d'implémentation et l'analyse comparative. Le principe de mise en œuvre des verrous distribués Redis La mise en œuvre des verrous distribués Redis

Utiliser Redis pour implémenter des verrous distribués en PHP Utiliser Redis pour implémenter des verrous distribués en PHP May 15, 2023 pm 03:51 PM

Avec le développement rapide d’Internet et la forte augmentation des visites de sites Web, l’importance des systèmes distribués est progressivement devenue importante. Dans les systèmes distribués, les problèmes de synchronisation simultanée et de cohérence des données sont inévitablement impliqués. Les verrous distribués, comme moyen de résoudre les problèmes de synchronisation simultanée, ont progressivement été largement utilisés dans les systèmes distribués. En PHP, vous pouvez utiliser Redis pour implémenter des verrous distribués, que cet article présentera. Qu'est-ce qu'un verrou distribué ? Dans un système distribué, lorsque plusieurs machines traitent la même tâche ensemble, afin d'éviter l'apparition de plusieurs machines

Comment utiliser les verrous distribués pour contrôler les accès simultanés dans MySQL ? Comment utiliser les verrous distribués pour contrôler les accès simultanés dans MySQL ? Jul 30, 2023 pm 10:04 PM

Comment utiliser les verrous distribués pour contrôler les accès simultanés dans MySQL ? Dans les systèmes de bases de données, un accès simultané élevé est un problème courant et les verrous distribués sont l'une des solutions courantes. Cet article explique comment utiliser les verrous distribués dans MySQL pour contrôler les accès simultanés et fournit des exemples de code correspondants. 1. Principe Les verrous distribués peuvent être utilisés pour protéger les ressources partagées afin de garantir qu'un seul thread puisse accéder à la ressource en même temps. Dans MySQL, les verrous distribués peuvent être implémentés de la manière suivante : Créez un fichier nommé lock_tabl

Explication détaillée de l'implémentation du verrouillage distribué dans Redis Explication détaillée de l'implémentation du verrouillage distribué dans Redis Jun 21, 2023 am 11:02 AM

Avec le développement rapide de l'Internet mobile et la croissance explosive du volume de données, les systèmes distribués deviennent de plus en plus populaires. Dans les systèmes distribués, le problème des opérations simultanées est devenu de plus en plus important lorsque plusieurs threads demandent des ressources partagées en même temps, ces ressources doivent être verrouillées pour garantir la cohérence des données. Les verrous distribués sont l'une des solutions efficaces pour implémenter des opérations simultanées dans les systèmes distribués. Cet article présentera en détail comment utiliser Redis pour implémenter des verrous distribués. Redis Basics Redis est un système de stockage clé-valeur basé sur la mémoire et distribué

Comparaison consul de l'implémentation Redis des verrous distribués Comparaison consul de l'implémentation Redis des verrous distribués Jun 20, 2023 pm 02:38 PM

Comparaison de Consul implémentant des verrous distribués dans Redis Dans les systèmes distribués, les verrous sont un mécanisme de synchronisation essentiel. En tant que base de données NoSQL couramment utilisée, la fonction de verrouillage distribué fournie par Redis a reçu une attention et une application généralisées. Cependant, Redis rencontre certains problèmes lors de la mise en œuvre des verrous distribués, tels que la réacquisition des verrous et le traitement des délais d'attente, c'est pourquoi de nouveaux outils ont été développés pour résoudre ces problèmes, notamment Consul. Cet article implémentera les verrous distribués dans Redis et implémentera Consul

See all articles