Redis实现分布式锁

本文详细介绍了如何使用Redis实现分布式锁,包括原理、测试过程及遇到的问题。通过设置锁的过期时间和使用Lua脚本确保原子性,解决了死锁和安全性问题,实现了更可靠的分布式锁解决方案。
摘要由CSDN通过智能技术生成

目录

Redis实现分布式锁

原理

测试代码

测试结果 

问题

优化一

解决办法

测试代码

测试结果

问题

优化二

解决办法

测试代码

测试结果


Redis实现分布式锁

原理

Redis中有这么个东西(key:k1 value:v1),k1这个key就是判断的锁

        当线程进来访问时,判断redis中是否有k1,如果没有,就设置k1然后访问资源,操作,此时另一个线程过来再次获取是否存在k1,当然此时k1肯定是存在的,所以该线程不能访问锁的资源,需要等待或者重新访问。

        当访问的线程访问完之后要释放k1也就是删除k1。

测试代码

package com.shao.seckill;

import com.shao.seckill.utils.UUIDUtil;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.data.redis.core.ValueOperations;
import org.springframework.data.redis.core.script.RedisScript;

import java.util.Collections;
import java.util.UUID;
import java.util.concurrent.TimeUnit;

@SpringBootTest
class SeckillApplicationTests {

    @Autowired
    private RedisTemplate redisTemplate;

    @Autowired
    private RedisScript<Boolean> script;

    @Test
    void contextLoads() {
        ValueOperations valueOperations = redisTemplate.opsForValue();
        //占位,如果key不存在才可以设置成功返回true
        Boolean isLock = valueOperations.setIfAbsent("k1", "v1");
        //如果占位成功,进行正常操作
        if(isLock){
            //操作
            valueOperations.set("name","xxxx");
            String name = (String) valueOperations.get("name");
            System.out.println(name);
            //操作完之后删除锁,让其它线程能够使用
            redisTemplate.delete("k1");
        }else{
            System.out.println("有线程在使用,请稍后尝试");
        }
    }

}

测试结果 

        可以正常锁和解锁资源

问题

        看似没有问题其实有很大

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值