springboot整合redis+lua实现getdel操作保证原子性

  1. 原始代码

脚本逻辑先获取redis的值,判断是否等于期望值。 条件成立则删除,不成立则返回0

Lua 复制代码
if redis.call('get', KEYS[1]) == ARGV[1] then
    return redis.call('del', KEYS[1])
end
return 0
  1. 测试代码

根据上面的逻辑加了测试, 在判断成功后等待5秒后执行删除操作。同时开启另外一个线程去修改这个key的值, 发现修改的线程一直阻塞。直到等待的线程5秒结束后且完成删除操作后,修改的线程才会执行。

原因:

redis是单线程执行,

Redis会将整个Lua脚本作为一个原子操作执行,这意味着脚本中的多个命令要么全部执行成功,要么全部失败。这有助于维护数据的原子性和一致性。

Redis执行Lua脚本时,它会自动锁定相关的键,以防止其他客户端对这些键进行并发修改。这确保了在脚本执行期间对键的访问是互斥的。

注意: 如果脚本中涉及多个key的操作并redis部署的是cluster模式时, 需要额外确认多个key都在一个slot中。还好我这就1个key!!!略过.............

java 复制代码
String str_script =
            // 1. 判断key的值是否等于期望值,等于则进行删除,不相等则直接结束
            "if (redis.call('get', KEYS[1]) == ARGV[1]) then\n" +
            "    local start = redis.call('TIME')[1] * 1000 + redis.call('TIME')[2] / 1000\n" +
            "    while (redis.call('TIME')[1] * 1000 + redis.call('TIME')[2] / 1000 - start) < 5000 do\n" +
            "        print('等待5秒结束.....')"+
            "    end\n"+
            // 2. 值判断成功,等待5秒执行删除操作
            "    return redis.call('del', KEYS[1])\n" +
            "end\n" +
            "return 0";
    public String getAndDelete(String key, String expectedValue) {
        log.info("start..................");
        DefaultRedisScript script = new DefaultRedisScript(str_script, Long.class);
        Object res = redisTemplate.execute(script, Collections.singletonList(key), expectedValue);
        log.info("end..................");
        return res.toString();
    }
相关推荐
小江的记录本23 分钟前
【MyBatis-Plus】MyBatis-Plus的核心特性、条件构造器、分页插件、乐观锁插件
java·前端·spring boot·后端·sql·tomcat·mybatis
驕傲的兎孒31 分钟前
基于 SpringBoot + Vue3 + AI 打造企业级售后服务支持平台 | 实战方案分享
人工智能·spring boot·后端
vx-程序开发31 分钟前
springboot在线装修管理系统-计算机毕业设计源码56278
java·c语言·spring boot·python·spring·django·php
難釋懷1 小时前
Redis分片集群手动故障转移
数据库·redis·缓存
无名-CODING1 小时前
从零开始!Vue3+SpringBoot前后端分离项目Docker部署实战(上):环境搭建与数据库容器化
数据库·spring boot·docker
程序员老乔2 小时前
Java 新纪元 — JDK 25 + Spring Boot 4 全栈实战(二):Valhalla落地,值类型如何让电商DTO内存占用暴跌
java·spring boot·c#
码界奇点2 小时前
基于Spring Boot和MyBatis的图书管理系统设计与实现
spring boot·后端·车载系统·毕业设计·mybatis·源代码管理
Luna-player3 小时前
第3章 Spring Boot的Web应用支持,个人学习笔记
前端·spring boot·学习
召田最帅boy3 小时前
SpringBoot实现AI智能评论审核与自动回复
人工智能·spring boot·后端·架构