SpringBoot通过RedisTemplate执行Lua脚本的方法步骤
lua 脚本
Redis 中使用 lua 脚本,我们需要注意的是,从 Redis 2.6.0后才支持 lua 脚本的执行。
使用 lua 脚本的好处:
原子操作:lua脚本是作为一个整体执行的,所以中间不会被其他命令插入。
减少网络开销:可以将多个请求通过脚本的形式一次发送,减少网络时延。
复用性:lua脚本可以常驻在redis内存中,所以在使用的时候,可以直接拿来复用,也减少了代码量。
1.RedisScript
首先你得引入spring-boot-starter-data-redis依赖,其次把lua脚本放在resources目录下。
@Bean public DefaultRedisScript<List> defaultRedisScript() {
DefaultRedisScript<List> defaultRedisScript = new DefaultRedisScript<>();
defaultRedisScript.setResultType(List.class);
defaultRedisScript.setScriptSource(new ResourceScriptSource(new
ClassPathResource("redis/demo.lua"))); return defaultRedisScript; }
在Spring Boot2.0的时候,上述配置没有问题,但在Spring
Boot1.5测试会出错,需要将List.class改为具体的返回类型(如Long.class)。
RedisScript的getSha1()方法可以获取脚本摘要。
2.调用脚本
/** * List设置lua的KEYS */ List<String> keyList = new ArrayList();
keyList.add("count"); keyList.add("rate.limiting:127.0.0.1"); /** *
用Mpa设置Lua的ARGV[1]
*/ Map<String, Object> argvMap = new HashMap<String,
Object>(); argvMap.put("expire", 10000); argvMap.put("times", 10); /** *
调用脚本并执行
*/ List result = redisTemplate1.execute(redisScript, keyList, argvMap); System.out.println(result);
若是出现序列化问题,可以指定序列化方式。
public <T> T execute(RedisScript<T> script, RedisSerializer<?> argsSerializer,
RedisSerializer<T> resultSerializer, List<K> keys, Object... args) { return
scriptExecutor.execute(script, argsSerializer, resultSerializer, keys, args); }
3.Lua脚本
--获取KEY local key1 = KEYS[1] local key2 = KEYS[2] --
获取ARGV[1],这里对应到应用端是一个List<Map>. -- 注意,这里接收到是的字符串,所以需要用csjon库解码成table类型 local
receive_arg_json = cjson.decode(ARGV[1]) --获取ARGV内的参数并打印 local expire = receive_arg_json.expire local times = receive_arg_json.times
总结
以上所述是小编给大家介绍的SpringBoot通过RedisTemplate执行Lua脚本的方法步骤,希望对大家有所帮助!
- SpringBoot+Redis执行lua脚本的5种方式总结
- Springboot+Redis执行lua脚本的项目实践
- springboot使用redisTemplate操作lua脚本
- springboot中使用redis并且执行调试lua脚本
- SpringBoot通过redisTemplate调用lua脚本并打印调试信息到redis log(方法步骤详解)
- SpringBoot+Redis执行lua脚本的方法步骤
- SpringBoot利用注解来实现Redis分布式锁
- SpringBoot基于Redis的分布式锁实现过程记录
- 关于SpringBoot 使用 Redis 分布式锁解决并发问题
- springboot+redis+lua实现分布式锁的脚本
相关文章
SpringBoot集成thymeleaf渲染html模板的步骤详解
这篇文章主要给大家详细介绍了SpringBoot集成thymeleaf如何使实现html模板的渲染,文中有详细的代码示例,具有一定的参考价值,需要的朋友可以参考下2023-06-06
Java Shell springboot通用Shell启动脚本方式
这篇文章主要介绍了Java Shell springboot通用Shell启动脚本方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-05-05
Java多线程工具CompletableFuture的使用教程
CompletableFuture实现了CompletionStage接口和Future接口,前者是对后者的一个扩展,增加了异步回调、流式处理、多个Future组合处理的能力。本文就来详细讲讲CompletableFuture的使用方式,需要的可以参考一下2022-08-08
spring框架cacheAnnotation缓存注释声明解析
这篇文章主要介绍了spring框架中cacheAnnotation注释声明缓存解析示例有需要的朋友可以借鉴参考下,希望能够有所帮助2021-10-10


最新评论