springboot使用lua脚本解决分布式锁释放的问题-创新互联

问题描述:

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

10年的漳州网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都营销网站建设的优势是能够根据用户设备显示端的尺寸不同,自动调整漳州建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联从事“漳州网站设计”,“漳州网站推广”以来,每个客户项目都认真落实执行。解决办法:

引入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 DefaultRedisScriptSECKILL_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
);

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


当前标题:springboot使用lua脚本解决分布式锁释放的问题-创新互联
本文来源:http://cdiso.cn/article/dspiop.html

其他资讯