您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

redis分布式锁实现原理是什么

2024/3/2 3:35:16发布19次查看
借助于redis中的命令setnx(key, value),key不存在就新增,存在就什么都不做。同时有多个客户端发送setnx命令,只有一个客户端可以成功,返回1(true);其他的客户端返回0(false)。
本教程操作环境:windows7系统、redis5.0.10版、dell g3电脑。
分布式锁的实现
随着业务发展的需要,原单体单机部署的系统被演化成分布式集群系统后,由于分布式系统多线程、多进程并且分布在不同机器上,这将使原单机部署情况下的并发控制锁策略失效,单纯的java api并不能提供分布式锁的能力。为了解决这个问题就需要一种跨jvm的互斥机制来控制共享资源的访问,这就是分布式锁要解决的问题!
分布式锁主流的实现方案:
基于数据库实现分布式锁
基于缓存(redis等)
基于zookeeper
这里,我们就基于redis实现分布式锁。
基本实现
借助于redis中的命令setnx(key, value),key不存在就新增,存在就什么都不做。同时有多个客户端发送setnx命令,只有一个客户端可以成功,返回1(true);其他的客户端返回0(false)。
主要使用redis setnx 命令
在指定的 key 不存在时,为 key 设置指定的值
设置成功,返回 1 。 设置失败,返回 0
redis> exists job # job 不存在(integer) 0 redis> setnx job "programmer" # job 设置成功(integer) 1 redis> setnx job "code-farmer" # 尝试覆盖 job ,失败(integer) 0 redis> get job # 没有被覆盖"programmer"
java代码
public void testlock() { // 执行redis的setnx命令 string uuid = uuid.randomuuid().tostring(); boolean lock = redistemplate.opsforvalue().setifabsent("lock", uuid, 5, timeunit.seconds); // 判断是否拿到锁 if (lock) { // 执行业务逻辑代码 // ... // 释放锁资源 (保证获取值和删除操作的原子性) lua脚本保证删除的原子性 string script = "if redis.call('get', keys[1]) == argv[1] then return redis.call('del', keys[1]) else return 0 end"; this.redistemplate.execute(new defaultredisscript<>(script), arrays.aslist("lock"), arrays.aslist(uuid));// if (strutil.equals(uuid,redistemplate.opsforvalue().get("lock"))){// redistemplate.delete("lock");// } } else { // 其他请求尝试获取锁 testlock(); } }
为了确保分布式锁可用,我们至少要确保锁的实现同时满足以下四个条件:
互斥性。在任意时刻,只有一个客户端能持有锁。
不会发生死锁。即使有一个客户端在持有锁的期间崩溃而没有主动解锁,也能保证后续其他客户端能加锁。
解铃还须系铃人。加锁和解锁必须是同一个客户端,客户端自己不能把别人加的锁给解了。
相关教程推荐:redis教程
以上就是redis分布式锁实现原理是什么的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product