谈谈 Redis 如何来实现分布式锁

谈谈 Redis 如何来实现分布式锁

基于 setnx 可以实现,但是不是可重入的。

基于 Hash 数据类型 + Lua脚本 可以实现可重入的分布式锁。

获取锁的 Lua 脚本:

释放锁的 Lua 脚本:

但是还是存在分布式问题,比如说,一个客户端在Redis主节点上面加了锁,但是由于主从同步的延迟问题,Redis从节点还没有同步到这个锁数据,这时候其他的客户端就可以在这个Redis从节点上面加相同的锁了。

引入 RedLock 解决方案。但是 RedLock 只是减少出问题的概率,而且性能差,不推荐使用。这玩意儿就是一种理论设计,平时工作用 setnx+补偿就行了

相关推荐
7***99871 小时前
GaussDB数据库中SQL诊断解析之配置SQL限流
数据库·sql·gaussdb
Wang's Blog2 小时前
MongoDB小课堂: 文档操作核心技术指南:主键机制、CRUD操作与最佳实践
数据库·mongodb
g***26793 小时前
最新SQL Server 2022保姆级安装教程【附安装包】
数据库·性能优化
风123456789~4 小时前
【OceanBase专栏】OB背景知识
数据库·笔记·oceanbase
4***72134 小时前
【玩转全栈】----Django模板语法、请求与响应
数据库·python·django
c***42104 小时前
Django视图与URLs路由详解
数据库·django·sqlite
数据库学啊4 小时前
团队小希望运维简单,时序数据库选型有什么推荐?
运维·数据库·时序数据库
2***65635 小时前
数据库操作与数据管理——Rust 与 SQLite 的集成
数据库·rust·sqlite
V***u4535 小时前
如何查看PostgreSQL的版本
数据库·postgresql