前言
经常会有这样一种业务逻辑,就是需要根据Redis中Key的规则,模糊查询对应的数据,当数据量少时,利用常规的命令也能满足需求,但是数据量大时,就会导致堵塞,就算是采用不堵塞的函数,如果数据需要显示的话,显示结果的时间也比较慢,用户体验不好。
Lua脚本
Redis 自2.6.0版本之后,就内置了Lua脚本,可以执行相关Lua脚本,提高操作效率;具体Lua脚本大家百度自行学习,不难;
应用:
这里记录的是在C#中的简单使用,其他语言也类似;
引用的包StackExchange.Redis, 我这里用的是2.0.601的版本;
代码实例:
如上图,这个方法是根据一个模糊Key值进行查询,中间字符串拼接的字符串就是lua脚本,使用redis.call()方法来执行Redis对应的指令;
然后将结果解析返回到前台;其他变量都是一些封装,其中db这个类型是IDatabase类型,相信用redis的小伙伴看见这个类型就明白了。
总结:
亲测这样的速度比直接执行循环get, 或执行mget指令效率好很多, 以上只是记录一个思路,lua脚本可以做很多事,不仅仅是查询,增删改查都可以,特别对批量操作,效率很不错。