一、引言
10年积累的成都网站设计、成都做网站、外贸网站建设经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站制作后付款的网站建设流程,更有江夏免费网站建设让你可以放心的选择与我们合作。
Redis是高性能的key-value数据库,
在很大程度克服了memcached这类key/value存储的不足,在部分场景下,是对关系数据库的良好补充
。
得益于超高性能和丰富的数据结构,Redis已成为当前架构设计中的首选key-value存储系统。
虽然Redis官网上提供了200多个命令,但做程序设计时还是避免不了为了实现一小步业务逻辑而多次调用Redis的情况。
以compare and set场景为例
。
如果使用Redis原生命令,需要从Redis中获取这个key,然后提取其中的值进行比对:
如果相等就不做处理;
如果不相等或者key不存在则将key设置成目标值。
仅仅一个单点的compare and set操作就需要与Redis通讯两次。
此外,这种分散操作无法利用Redis的原子特性,占用多次网络IO。
今天我们就来探讨一下如何优雅地应对上述场景。
二、Redis与Lua
在介绍Lua之前,我们需要先对这个语言有个初步了解。Lua 是一个小巧的脚本语言,几乎可以运行在所有操作系统和平台上。我们一般不会用Lua处理特别复杂的事务,因此只需了解一些lua的基本语法即可。
Redis问世之后,其开发者也意识到了开篇提到的问题,因此Redis从2.6版本开始支持Lua脚本。新版本的Redis还支持Lua Script debug,感兴趣的小伙伴可以去官网的Documentation中找到对应介绍和QuickStart。
有了Lua脚本之后,使用Redis程序时便能够在以下方面实现显著提升:
所以现在流传一句话:要想学好Redis,必会Lua Script。
三、通过Lua脚本实现compare and set
接下来我们就实现一个简单的compare and set,并通过这个例子感受一下Lua脚本给Redis使用带来的全新体验。
首先看一下如何让Redis执行Lua脚本。
3.1 Redis的EVAL
- Redis 127.0.0.1:6379> EVAL script numkeys key [key ...] arg [arg ...]
这里借用一下官网的例子。
上述脚本直接返回了入参。
大家可以简单地将KEYS[1],KEYS[2], ARGV[1],ARGV[2]理解为占位符。
3.2 执行脚本文件和缓存脚本
如果只能在命令行中写脚本执行,遇到复杂的脚本程序岂不是会抓狂?
下面我们来看一下,如何让Redis执行Lua脚本文件,同时也验证一下lua脚本的复用特性(以后我们再也不需要定期批量删除某些符合特定规则的key了)。
- Redis 127.0.0.1:6379> SCRIPT LOAD script
- Redis 127.0.0.1:6379> EVALSHA sha1 numkeys key [key ...] arg [arg ...]
Redis提供了一个SCRIPTLOAD命令,命令后面的script即为Lua脚本。命令将脚本script添加到脚本缓存中,但并不立即执行这个脚本。执行命令后,Redis会返回一个SHA1串,第二个EVALSHA命令即可执行。
需要注意的是,脚本可以在缓存中保留无限长的时间,直到执行完SCRIPT FLUSH。我们来看一下效果。
Redis还支持直接执行Lua脚本文件。
首先编写并存储一个Lua脚本。
然后调用Redis-cli –eval命令。
Redis-cli –eval命令语法基本与原eval语法相同。
3.3 使用Lua脚本实现compare and set
compareand set的实现逻辑是这样的:
首先获取Redis中指定key的value,然后与给定值进行比较:
如果相等,则将key设定为目标值并返回一个标识符;
如果不相等,则不作任何操作并返回一个标识符。
- if Redis.call('get', KEYS[1]) == ARGV[1] then
- Redis.call('set', KEYS[1], ARGV[2]);
- return 1
- else
- return 0 end
下面我们来测试一下这个脚本。
首先向Redis的指定key compareAndSet:key写入一个值value。
在Redis中执行lua脚本。
可以看到第一次执行返回1,说明修改成功了;
再使用原参数执行时返回0,说明没有做任何修改。
我们再查询一下compareAndSet:key这个key。
可以看到compareAndSet:key这个key已经被修改为new_value了。
四、总结
我们通过lua脚本实现了一个简单的compareAndSet操作。
下面我们通过这个例子来验证一下开篇提到的特性。
读到这里,希望你已经对Redis+Lua有了一定的了解,并能使用脚本完成一些简单的复合操作。后续还会继续更新一些基于Lua脚本+java程序实现的分布式数据结构,如延迟队列、可重入锁等,感兴趣的小伙伴可以持续关注。
【本文是专栏机构宜信技术学院的原创文章,微信公众号“宜信技术学院( id: CE_TECH)”】
戳这里,看该作者更多好文
当前标题:Redis进阶应用:Redis+Lua脚本实现复合操作
本文URL:http://www.mswzjz.cn/qtweb/news25/79325.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能