springboot使用lua脚本解决Redis分布式锁释放的问题

问题描述:

判断锁的标志和删除锁不是原子操作。

解决办法:

引入lua脚本

1.创建 lua文件

放在resources目录下

获取k的值,比较k的值是否一致,若一致就删除,不一致就返回0

 local k = KEYS[1]

 local v = ARGV[1]
-- 获取k的值
local id = redis.call("get",k)
-- 比较k的值是否一致
 if (v==id)
 then
-- 若一致就删除
 return redis.call("del",k)
 end
-- 不一致就返回0
 return 0

2.springboot读取配置文件

用静态代码块,只加载一次


    private static final DefaultRedisScript<Long> SECKILL_SCRIPT;

    static {
        SECKILL_SCRIPT = new DefaultRedisScript<>();
        SECKILL_SCRIPT.setLocation(new ClassPathResource("test.lua")); //lua脚本路径
        SECKILL_SCRIPT.setResultType(Long.class); //返回值
    }

3.执行

stringRedisTemplate.execute(
    SECKILL_SCRIPT, 
    Collections.singletonList("a"), // K
     "b"        // V
);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值