SpringBoot 执行Lua脚本 服务端执行 减少性能损耗 优化性能 优化连接性能

介绍

通过 Redis 执行 Lua 脚本时,所有的操作都在服务器端完成,而不是多次通过网络进行请求。这可以显著减少网络延迟,尤其是在需要多次与 Redis 交互的场景中。多个操作可以在 Lua 脚本中组合成一个操作,而不是分多次请求,这减少了客户端与 Redis 之间的往返次数,从而提升了性能。脚本的执行是原子的。意味着整个 Lua 脚本会在 Redis 服务器中一次性执行,不会被中断,确保了操作的原子性。

创建Lua脚本

redis 脚本 键不存在就添加 不存在 就删除例子,

在资源文件中创建

resources/redis.lua

java 复制代码
if redis.call('EXISTS', KEYS[1]) == 1 then  -- 检查传入的键 (KEYS[1]) 是否存在

    redis.call('DEL', KEYS[1])  -- 删除键 (KEYS[1])
    
else

    redis.call('SET', KEYS[1], ARGV[1])  -- 如果键不存在,设置键 (KEYS[1]) 的值为 (ARGV[1])
    
end

return 1  -- 返回1,表示脚本成功执行
  • KEYS[1] 是传入脚本的第一个键
  • ARGV[1] 是传入脚本的第一个值

执行脚本

java 复制代码
@RequiredArgsConstructor
public class RedisScript {

    private static final DefaultRedisScript<Long> script ;
    //Long为返回值类型

    static {

        script=new DefaultRedisScript<>();

        //初始化脚本 resources\redis.lua
        script.setLocation(new ClassPathResource("redis.lua"));

        //设置返回值类型
        script.setResultType(Long.class);

    }

    public static Long runScript(StringRedisTemplate  redisTemplate){

        // 传递多个参数
        //List<String> keys = Arrays.asList("key1", "key2");  // 两个键
        //List<String> args = Arrays.asList("value1", "value2");  // 两个值

       return redisTemplate.execute(script,
                Collections.singletonList("dpc"), //Key
                UUID.randomUUID().toString() ); //Value
    }


}

static 代码块是静态初始化块,它会在类加载时被执行一次。这里的 static 代码块用于初始化静态变量 script。

接口调用

java 复制代码
 private final StringRedisTemplate redisTemplate;

@GetMapping("/redis")
public Long redis(){
    return  RedisScript.runScript(redisTemplate);
}
相关推荐
聪明的笨猪猪1 天前
Java SE “JDK1.8新特性”面试清单(含超通俗生活案例与深度理解)
java·经验分享·笔记·面试
Excuse_lighttime1 天前
除自身以外数组的乘积
java·数据结构·算法·leetcode·eclipse·动态规划
Vahala0623-孔勇1 天前
Redisson分布式锁源码深度解析:RedLock算法、看门狗机制,以及虚拟线程下的锁重入陷阱与解决
java·开发语言·分布式
程序员三明治1 天前
【重学数据结构】队列 Queue
数据结构·后端·算法
Coision.1 天前
Linux C: 函数
java·c语言·算法
杜小暑1 天前
数据结构之双向链表
c语言·数据结构·后端·算法·链表·动态内存管理
经典19921 天前
Elasticsearch 讲解及 Java 应用实战:从入门到落地
java·大数据·elasticsearch
铅笔侠_小龙虾1 天前
JVM深入研究--JHSDB (jvm 分析工具)
java·开发语言·jvm
豆浆Whisky1 天前
Go实现百万级连接:资源管控与性能平衡的艺术|Go语言进阶(9)
后端·go
majunssz1 天前
深入剖析Spring Boot依赖注入顺序:从原理到实战
java·数据库·spring boot