


Comment développer des fonctions de verrouillage distribuées à l'aide de Redis et Java
Comment utiliser Redis et Java pour développer une fonction de verrouillage distribué
- Introduction
Le verrouillage distribué est un mécanisme permettant d'obtenir un accès mutuellement exclusif aux ressources partagées dans un système distribué. Lorsque plusieurs nœuds accèdent à des ressources partagées en même temps, il est nécessaire de s'assurer qu'un seul nœud accède et que les autres nœuds doivent attendre. Redis est une base de données en mémoire couramment utilisée avec des performances et une fiabilité élevées, et est très adaptée à la mise en œuvre de verrous distribués. - Commande setnx de Redis
La commande setnx de Redis peut être utilisée pour définir la valeur d'une clé, mais l'opération de configuration ne sera effectuée que lorsque la clé n'existe pas. Cette fonctionnalité peut être utilisée pour mettre en œuvre des opérations d'acquisition de verrous distribués. Utilisez la commande setnx pour essayer d'abord de définir une clé avec un délai d'expiration. Si le réglage réussit, cela signifie que le verrou a été acquis avec succès. Sinon, cela signifie que le verrou a été acquis par d'autres nœuds. - Exemple de code Java
Ce qui suit est un exemple de code qui utilise le langage Java et Redis pour implémenter des verrous distribués :
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); } }
- Exemple de description
Dans l'exemple de code ci-dessus, la bibliothèque Jedis est utilisée pour faire fonctionner Redis. Tout d'abord, une constanteLOCK_KEY
est définie comme la clé du verrou distribué. Cette clé doit rester unique parmi tous les nœuds. De plus, une constanteLOCK_TIMEOUT
est définie pour représenter le délai d'expiration du verrouillage.LOCK_KEY
作为分布式锁的键,这个键在所有节点中必须保持唯一。另外,设置了一个LOCK_TIMEOUT
常量来表示锁的超时时间。
在lock
方法中,首先获取当前时间作为开始时间,然后使用一个无限循环来尝试获取分布式锁。在循环中,使用Redis的set
命令进行设置操作,设置键为LOCK_KEY
,值为"locked",并且设置了NX
和PX
选项,NX
表示只有键不存在时才执行设置操作,PX
表示设置键的过期时间为LOCK_TIMEOUT
毫秒。
如果设置成功,则表示获取锁成功,方法返回true
;否则继续进行重试,每次重试时会等待100毫秒。同时,还需要判断获取锁的时间是否超过了LOCK_TIMEOUT
的值,如果超过则表示获取锁的等待时间已经过长,放弃获取锁,并返回false
。
在unlock
方法中,通过调用del
- Dans la méthode
lock
, obtenez d'abord l'heure actuelle comme heure de début, puis utilisez une boucle infinie pour essayer d'acquérir le verrou distribué. Dans la boucle, utilisez la commande set
de Redis pour effectuer l'opération de configuration. La clé set est LOCK_KEY
, la valeur est "verrouillée" et NX
. et l'option PX
, NX
signifie que l'opération de paramétrage sera effectuée uniquement lorsque la clé n'existe pas, PX
signifie que le délai d'expiration de la clé La clé définie est LOCK_TIMEOUT</ code>millisecondes. <li><br>Si le réglage réussit, cela signifie que le verrou est acquis avec succès et que la méthode renvoie <code>true
; sinon, continuez à réessayer et attendra 100 millisecondes pour chaque nouvelle tentative. Dans le même temps, il est également nécessaire de déterminer si le temps d'acquisition du verrou dépasse la valeur de LOCK_TIMEOUT
. S'il dépasse, cela signifie que le temps d'attente pour acquérir le verrou a été trop long, abandonnez l'acquisition du verrou et retournez false
. unlock
, supprimez la clé du verrou distribué en appelant la commande del
. - Exemple d'appel
- Ce qui suit est un exemple d'appel utilisant l'exemple de code :
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(); } } }
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds





Le mode Redis Cluster déploie les instances Redis sur plusieurs serveurs grâce à la rupture, à l'amélioration de l'évolutivité et de la disponibilité. Les étapes de construction sont les suivantes: Créez des instances de redis étranges avec différents ports; Créer 3 instances Sentinel, Moniteur Redis Instances et basculement; Configurer les fichiers de configuration Sentinel, ajouter des informations d'instance Redis de surveillance et des paramètres de basculement; Configurer les fichiers de configuration d'instance Redis, activer le mode de cluster et spécifier le chemin du fichier d'informations de cluster; Créer un fichier nœuds.conf, contenant des informations de chaque instance redis; Démarrez le cluster, exécutez la commande CREATE pour créer un cluster et spécifiez le nombre de répliques; Connectez-vous au cluster pour exécuter la commande d'informations de cluster pour vérifier l'état du cluster; faire

PHP et Python ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1.Php convient au développement Web, avec une syntaxe simple et une efficacité d'exécution élevée. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et des bibliothèques riches.

PHP est un langage de script largement utilisé du côté du serveur, particulièrement adapté au développement Web. 1.Php peut intégrer HTML, traiter les demandes et réponses HTTP et prend en charge une variété de bases de données. 2.PHP est utilisé pour générer du contenu Web dynamique, des données de formulaire de traitement, des bases de données d'accès, etc., avec un support communautaire solide et des ressources open source. 3. PHP est une langue interprétée, et le processus d'exécution comprend l'analyse lexicale, l'analyse grammaticale, la compilation et l'exécution. 4.PHP peut être combiné avec MySQL pour les applications avancées telles que les systèmes d'enregistrement des utilisateurs. 5. Lors du débogage de PHP, vous pouvez utiliser des fonctions telles que error_reportting () et var_dump (). 6. Optimiser le code PHP pour utiliser les mécanismes de mise en cache, optimiser les requêtes de base de données et utiliser des fonctions intégrées. 7

Comment effacer les données Redis: utilisez la commande flushall pour effacer toutes les valeurs de clé. Utilisez la commande flushdb pour effacer la valeur clé de la base de données actuellement sélectionnée. Utilisez SELECT pour commuter les bases de données, puis utilisez FlushDB pour effacer plusieurs bases de données. Utilisez la commande del pour supprimer une clé spécifique. Utilisez l'outil Redis-CLI pour effacer les données.

PHP convient au développement Web, en particulier dans le développement rapide et le traitement du contenu dynamique, mais n'est pas bon dans les applications de la science des données et de l'entreprise. Par rapport à Python, PHP présente plus d'avantages dans le développement Web, mais n'est pas aussi bon que Python dans le domaine de la science des données; Par rapport à Java, PHP fonctionne moins bien dans les applications au niveau de l'entreprise, mais est plus flexible dans le développement Web; Par rapport à JavaScript, PHP est plus concis dans le développement back-end, mais n'est pas aussi bon que JavaScript dans le développement frontal.

Pour lire une file d'attente à partir de Redis, vous devez obtenir le nom de la file d'attente, lire les éléments à l'aide de la commande LPOP et traiter la file d'attente vide. Les étapes spécifiques sont les suivantes: Obtenez le nom de la file d'attente: Nommez-le avec le préfixe de "Fitre:" tel que "Fitre: My-Quyue". Utilisez la commande LPOP: éjectez l'élément de la tête de la file d'attente et renvoyez sa valeur, telle que la file d'attente LPOP: My-Queue. Traitement des files d'attente vides: si la file d'attente est vide, LPOP renvoie NIL et vous pouvez vérifier si la file d'attente existe avant de lire l'élément.

Les raisons pour lesquelles PHP est la pile technologique préférée pour de nombreux sites Web incluent sa facilité d'utilisation, son soutien communautaire solide et son utilisation généralisée. 1) Facile à apprendre et à utiliser, adapté aux débutants. 2) Avoir une énorme communauté de développeurs et des ressources riches. 3) Largement utilisé dans WordPress, Drupal et d'autres plateformes. 4) Intégrez étroitement aux serveurs Web pour simplifier le déploiement du développement.

PHP et Python ont chacun leurs propres avantages et conviennent à différents scénarios. 1.PHP convient au développement Web et fournit des serveurs Web intégrés et des bibliothèques de fonctions riches. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et une bibliothèque standard puissante. Lors du choix, il doit être décidé en fonction des exigences du projet.
