SpringBoot通过RedisTemplate执行Lua脚本的方法步骤
lua脚本
Redis中使用lua脚本,我们需要注意的是,从Redis2.6.0后才支持lua脚本的执行。
使用lua脚本的好处:
原子操作:lua脚本是作为一个整体执行的,所以中间不会被其他命令插入。
减少网络开销:可以将多个请求通过脚本的形式一次发送,减少网络时延。
复用性:lua脚本可以常驻在redis内存中,所以在使用的时候,可以直接拿来复用,也减少了代码量。
1.RedisScript
首先你得引入spring-boot-starter-data-redis依赖,其次把lua脚本放在resources目录下。
@BeanpublicDefaultRedisScriptdefaultRedisScript(){ DefaultRedisScript
defaultRedisScript=newDefaultRedisScript<>(); defaultRedisScript.setResultType(List.class); defaultRedisScript.setScriptSource(newResourceScriptSource(new ClassPathResource("redis/demo.lua")));returndefaultRedisScript;}
在SpringBoot2.0的时候,上述配置没有问题,但在Spring
Boot1.5测试会出错,需要将List.class改为具体的返回类型(如Long.class)。
RedisScript的getSha1()方法可以获取脚本摘要。
2.调用脚本
/***List设置lua的KEYS*/ListkeyList=newArrayList(); keyList.add("count");keyList.add("rate.limiting:127.0.0.1");/***
用Mpa设置Lua的ARGV[1]
*/MapargvMap=newHashMap ();argvMap.put("expire",10000);argvMap.put("times",10);/***
调用脚本并执行
*/Listresult=redisTemplate1.execute(redisScript,keyList,argvMap); System.out.println(result);
若是出现序列化问题,可以指定序列化方式。
publicTexecute(RedisScript script,RedisSerializer>argsSerializer, RedisSerializer resultSerializer,List keys,Object...args){return scriptExecutor.execute(script,argsSerializer,resultSerializer,keys,args);}
3.Lua脚本
--获取KEYlocalkey1=KEYS[1]localkey2=KEYS[2]--
获取ARGV[1],这里对应到应用端是一个List
receive_arg_json=cjson.decode(ARGV[1])--获取ARGV内的参数并打印localexpire= receive_arg_json.expirelocaltimes=receive_arg_json.times
总结
以上所述是小编给大家介绍的SpringBoot通过RedisTemplate执行Lua脚本的方法步骤,希望对大家有所帮助!