SpringBoot通过RedisTemplate执行Lua脚本的方法步骤

网友投稿 979 2023-06-26

SpringBoot通过RedisTemplate执行Lua脚本的方法步骤

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 defaultRedisScript() {

DefaultRedisScript 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 keyList = new ArrayList();

keyList.add("count"); keyList.add("rate.limiting:127.0.0.1"); /** *

用Mpa设置Lua的ARGV[1]

*/ Map argvMap = new HashMap

Object>(); arhttp://gvMap.put("expire", 10000); argvMap.put("times", 10); /** *

调用脚本并执行

*/ List result = redisTemplate1.execute(redisScript, keyList, argvMap);

System.out.println(result);

若是出现序列化问题,可以指定序列化方式。

public T execute(RedisScript script, RedisSerializer> argsSerializer,

RedisSerializer&http://lt;T> resultSerializer, List 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. -- 注意,这里接收到是的字符串,所以需要用csjon库解码成table类型 local

receive_arg_json = cjson.decode(ARGV[1]) --获取ARGV内的参数并打印 local expire =

receive_arg_json.expire local times = receive_arg_json.times

总结

以上所述是给大家介绍的SpringBoot通过Rehttp://disTemplate执行Lua脚本的方法步骤,希望对大家有所帮助!

Object>(); arhttp://gvMap.put("expire", 10000); argvMap.put("times", 10); /** *

调用脚本并执行

*/ List result = redisTemplate1.execute(redisScript, keyList, argvMap);

System.out.println(result);

若是出现序列化问题,可以指定序列化方式。

public T execute(RedisScript script, RedisSerializer> argsSerializer,

RedisSerializer&http://lt;T> resultSerializer, List 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. -- 注意,这里接收到是的字符串,所以需要用csjon库解码成table类型 local

receive_arg_json = cjson.decode(ARGV[1]) --获取ARGV内的参数并打印 local expire =

receive_arg_json.expire local times = receive_arg_json.times

总结

以上所述是给大家介绍的SpringBoot通过Rehttp://disTemplate执行Lua脚本的方法步骤,希望对大家有所帮助!

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:SpringBoot通过redisTemplate调用lua脚本并打印调试信息到redis log(方法步骤详解)
下一篇:线程池中使用spring aop事务增强
相关文章

 发表评论

暂时没有评论,来抢沙发吧~