Maison >Java >javaDidacticiel >Comment implémenter un verrou distribué à l'aide de Redis
Eh bien, chaque fois que nous travaillons dans notre système local, tout fonctionne comme du beurre. C'est pourquoi nous appelons "Pas de meilleur endroit que 127.0.0.1" mais RÉVEILLEZ-VOUS À LA RÉALITÉ
Eh bien, les choses ne fonctionnent pas toujours en production comme prévu. Surtout lorsque vous exécutez plusieurs instances de votre application.
? Comme vous pouvez le voir, si plusieurs instances de notre application sont en cours d'exécution, disons que notre client demande à marquer un utilisateur comme utilisateur payant dans notre base de données.
Ça semble bien, n'est-ce pas ? Pas de problème jusqu'à présent, n'est-ce pas.
Eh bien, oui jusqu'à présent, il n'y a pas de problème. Mais que se passe-t-il si nous voulons écrire une logique métier comme :-
⚡️ Comme nous le savons (supposons que nous utilisons MySQL ici) les bases de données MySQL sont conformes à ACID, ce qui signifie que toute requête sera atomique et isolée. ce qui signifie que la requête MySQL sera exécutée de manière atomique, soit elle réussira, soit elle échouera. Mais il ne s'arrêtera pas entre-temps.
? Mais il y a un problème ici. Réfléchissez, réfléchissez....
Que se passera-t-il si à l'étape 2, une demande supplémentaire arrive pour annuler le paiement, puis cette requête s'exécute en premier et marque l'utilisateur comme gratuit, puis l'étape 3 s'exécute et l'utilisateur est marqué comme payant.
?? Hourra, l'utilisateur a eu accès à nos produits sans même payer.
✅ Voici le sauveur, Locks
? Lock est une structure qui permet à un seul thread à la fois d'entrer dans une section critique (bloc de code auquel plusieurs travailleurs ne doivent pas accéder, c'est-à-dire les threads)
Par conséquent, nous acquerrons le verrouillage avant et le libérerons après la fin de l'opération :-
Maintenant, voici le problème : si nous utilisons une structure de données de verrouillage en mémoire ou tout autre verrou basé sur la mémoire, il sera éligible pour une instance pour notre application. qu'en est-il des autres instances exécutant le même code et mis à jour dans la base de données ?
Eh bien, voici le concept de verrouillage distribué
Ici, le verrou agit comme un service centralisé, où si une instance de notre service acquiert le verrou, les autres ne peuvent pas utiliser la même clé.
QUELLE CLÉ POURRAIT ÊTRE ICI DANS LE SERVICE DE PAIEMENT ?
? Pour un utilisateur effectuant un paiement, la clé pourrait être la combinaison de = "PAYMENT_" + user_id + montant
Et ce sera unique par utilisateur. Et cette clé restera la même en cas d’utilisateur effectuant un paiement ou annulant un paiement. Par conséquent, lorsqu'une action se produit, une autre action ne peut pas avoir lieu car les deux actions tenteront d'acquérir la même clé.
? Qu'est-ce que c'est que la clé, acquérir le verrou, libérer le verrou. Et surtout, comment Redis est-il utilisé ?
Mais voici les quelques problèmes avec une seule instance Redis :-
? Ainsi, si le verrou est acquis sur le maître, et pendant la communication avec le réplica, si le maître tombe en panne avant la synchronisation avec le réplica. La réplique deviendra maître où le verrouillage sur la même clé sera disponible pour acquérir celui qui a été acquis sur le maître plus tôt.
Deux instances de nos services pourront acquérir le verrou sur redis même en ayant deux instances (maître-réplique).
Acquisition du verrouillage : - Nous allons essayer d'acquérir le verrouillage sur plusieurs instances Redis avec un délai d'expiration du verrouillage
Validation du verrou : - le verrou sera considéré comme acquis si les instances Redis majeures ont obtenu le verrou acquis pour le client
Libération du verrou : - Lors de la libération du verrou, toutes les instances libèrent le verrou
Et oui c'est tout.
❤️ Merci pour votre lecture et abonnez-vous à notre newsletter pour plus d'articles de ce type :- https://www.serversidedigest.com/
Pour plus d'informations :-
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!