Redis锁的使用

本文介绍了使用SpringBoot的RedisLockUtils类实现的分布式锁功能,包括获取锁、业务处理以及自动解锁的过程。利用Redis的SETNX命令保证了锁的原子性和唯一性。
摘要由CSDN通过智能技术生成
@Service("RedisLockUtils")
@Slf4j
public class RedisLockUtils {
    @Autowired
    private RedisTemplate<String, String> redisTemplate;

    public static final String LOCK_KEY="update:aaaa";

    public void lock(String key) {
        String lockKey = LOCK_KEY+key ;
        String value = Thread.currentThread().getName();
        // 使用SETNX命令尝试获取锁
/*设置锁:底层使用 Redis 命令 SETNX(SET if Not eXists)设置 Redis 锁。SETNX 这个命令用于检测一个指定key是否存在,如果key不存在,那么会设置该key,返回一个1,如果key存在那么返回一个0。*/
        Boolean acquiredLock = redisTemplate.opsForValue().setIfAbsent(lockKey, value);
        log.info("变更获取指定key的redis锁状态" + key+"   "+lockKey+"   "+acquiredLock);
        if (acquiredLock != null && acquiredLock) {
            // 成功获取锁,设置锁的超时时间
            redisTemplate.expire(lockKey, 1, TimeUnit.MINUTES);
            return;
        }
        throw new Exception("锁已经被获取,请稍后重试!");
    }

    public void unLock(String key) {
        String lockKey = LOCK_KEY+key ;
        String currentValue = redisTemplate.opsForValue().get(lockKey);
        if (currentValue != null && currentValue.equals(Thread.currentThread().getName())) {
            // 只有持有锁的线程才能释放锁
            redisTemplate.delete(lockKey);
        }
    }
}

	@Test
	public void test() {
        //获取锁
		redisLockUtils.lock("0001");
		try {
          //处理业务锁
		  System.out.println("处理业务");
		} catch (Exception e) {
			log.error(e.getMessage());

		} finally {
			//释放锁
			redisLockUtils.unLock("0001");

		}
		
	}

  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值