加入收藏 | 设为首页 | 会员中心 | 我要投稿 核心网 (https://www.hxwgxz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 建站 > 正文

Redis进阶应用:Redis+Lua脚本实现复合操作

发布时间:2019-08-07 02:49:32 所属栏目:建站 来源:李崇
导读:一、引言 Redis是高性能的key-value数据库,在很大程度克服了memcached这类key/value存储的不足,在部分场景下,是对关系数据库的良好补充。得益于超高性能和丰富的数据结构,Redis已成为当前架构设计中的首选key-value存储系统。 虽然Redis官网上提供了20

这里借用一下官网的例子。

Redis进阶应用:Redis+Lua脚本实现符合操作 

上述脚本直接返回了入参。

  • eval为Redis关键字; 
  • 第一个引号中的内容就是Lua脚本; 
  • 2为参数个数; 
  • key1和key2是KEYS[1]、KEYS[2]的入参; 
  • first和second是ARGV[1],ARGV[2]的入参。

大家可以简单地将KEYS[1],KEYS[2], ARGV[1],ARGV[2]理解为占位符。

3.2 执行脚本文件和缓存脚本

如果只能在命令行中写脚本执行,遇到复杂的脚本程序岂不是会抓狂?

下面我们来看一下,如何让Redis执行Lua脚本文件,同时也验证一下lua脚本的复用特性(以后我们再也不需要定期批量删除某些符合特定规则的key了)。

  1. Redis 127.0.0.1:6379> SCRIPT LOAD  script 
  2. Redis 127.0.0.1:6379> EVALSHA sha1  numkeys key [key ...] arg [arg ...] 

Redis提供了一个SCRIPTLOAD命令,命令后面的script即为Lua脚本。命令将脚本script添加到脚本缓存中,但并不立即执行这个脚本。执行命令后,Redis会返回一个SHA1串,第二个EVALSHA命令即可执行。

需要注意的是,脚本可以在缓存中保留无限长的时间,直到执行完SCRIPT FLUSH。我们来看一下效果。

Redis进阶应用:Redis+Lua脚本实现符合操作 

Redis还支持直接执行Lua脚本文件。首先编写并存储一个Lua脚本。

Redis进阶应用:Redis+Lua脚本实现符合操作 

然后调用Redis-cli –eval命令。

Redis进阶应用:Redis+Lua脚本实现符合操作 

Redis-cli –eval命令语法基本与原eval语法相同。

3.3 使用Lua脚本实现compare and set 

compareand set的实现逻辑是这样的:首先获取Redis中指定key的value,然后与给定值进行比较:如果相等,则将key设定为目标值并返回一个标识符;如果不相等,则不作任何操作并返回一个标识符。

  1. if Redis.call('get', KEYS[1]) == ARGV[1]  then 
  2.      Redis.call('set', KEYS[1], ARGV[2]); 
  3.      return 1 
  4. else 
  5.      return 0 end 

下面我们来测试一下这个脚本。

首先向Redis的指定key compareAndSet:key写入一个值value。

Redis进阶应用:Redis+Lua脚本实现符合操作 

(编辑:核心网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读