前言
Redis从2.6版本开始引入对Lua脚本的支持,通过在服务器中嵌入Lua环境,Redis客户端可以使用Lua脚本,直接在服务端原子的执行多个Redis命令。
其中,使用EVAL命令可以直接对输入的脚本进行求值:
redis>EVAL "return 'hello world'" 0 "hello world"
使用脚本的好处如下:
1.减少网络开销:本来5次网络请求的操作,可以用一个请求完成,原先5次请求的逻辑放在redis服务器上完成。使用脚本,减少了网络往返时延。
2.原子操作:Redis会将整个脚本作为一个整体执行,中间不会被其他命令插入。
3.复用:客户端发送的脚本会永久存储在Redis中,意味着其他客户端可以复用这一脚本而不需要使用代码完成同样的逻辑。
Redis执行Lua脚本
实现一个访问频率控制,某个ip在短时间内频繁访问页面,需要记录并检测出来,就可以通过Lua脚本高效的实现
在redis客户端机器上,新建一个文件ratelimiting.lua,内容如下
local times = redis.call('incr',KEYS[1]) if times == 1 then redis.call('expire',KEYS[1], ARGV[1]) end if times > tonumber(ARGV[2]) then return 0 end return 1
在redis客户端机器上,如何测试这个脚本呢?如下:
redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3
--eval参数是告诉redis-cli读取并运行后面的Lua脚本,ratelimiting.lua是脚本的位置,后面跟着是传给Lua脚本的参数。其中","前的rate.limiting:127.0.0.1是要操作的键,可以再脚本中用KEYS[1]获取,","后面的10和3是参数,在脚本中能够使用ARGV[1]和ARGV[2]获得。注:","两边的空格不能省略,否则会出错
结合脚本的内容可知这行命令的作用是将访问频率限制为每10秒最多3次,所以在终端中不断的运行此命令会发现当访问频率在10秒内小于或等于3次时返回1,否则返回0。
测试运行如下:
[root@rhel6 redis-learning]# redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3 (integer) 1 [root@rhel6 redis-learning]# redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3 (integer) 1 [root@rhel6 redis-learning]# redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3 (integer) 1 [root@rhel6 redis-learning]# redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3 (integer) 0 [root@rhel6 redis-learning]# redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3 (integer) 0
补充:
现在Lua脚本用在很多游戏上,主要是Lua脚本做到可以嵌入到其他程序中运行,游戏升级的时候,可以直接升级脚本,而不用重新安装游戏。比如游戏的很多关卡,只需要增加lua脚本,在游戏中嵌入Lua解释器,游戏团队线上更新Lua脚本,然后游戏自动下载最新的游戏关卡。例如之前很多的游戏《愤怒的小鸟》就是用Lua语言实现的关卡。
摘自《Redis入门指南》
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
更新日志
- 金海心.-.[金海心].专辑.(APE+CUE)
- 破碎之地新手能力选择推荐 能力效果分析
- 《小猫咪大城市》Steam”好评如潮”!好评率高达95%
- 星穹铁道梦境护照17收集位置 晨星与昏星贴纸收集位置大全
- 苏曼《佳人曲HQ》头版限量[低速原抓WAV+CUE]
- 最终幻想14 x 最终幻想XI联动任务星歌异闻再临
- 华纳兄弟:《自杀小队》失败 导致损失2亿美元收入
- 孙露《同名专辑HQ》头版限量编号[低速原抓WAV+CUE]
- 崩坏星穹铁道2.2他落下的羽毛怎么做 他落下的羽毛隐藏成就攻略
- 三国谋定天下品鉴会圆满落幕 公测定档掀起SLG手游新热潮
- [新世纪]SacredSpaMusicSeries-恬静时分QuietDays[FLAC+CUE]
- [新世纪]SacredSpaMusicSeries-时间面纱WrappedinStillness[FLAC+CUE]
- [新世纪]RealMusic-Ayman2CD[FLAC]
- 斯琴高丽《斯琴高丽歌曲合集》[320K/MP3][322.2MB]
- 沙宝亮《沙宝亮歌曲合集》[320K/MP3][176.5MB]