Redis 整合Lua脚本
简介:Lua是一种由轻量级C语言编写的脚本,跟数据的存储过程有点类似,使用Lua脚本来执行Redis命令好处如下:
一次性发送多个命令,减少网络开销;
Redis会将整个脚本作为一个整体执行,不会被其他请求打断,保持原子性;
对于复杂的组合命令,我们可以放在文件中,可以实现命令复用;
1. Redis中调用Lua脚本
A. eval script numkeys keys args
script:lua脚本;
numkeys:指定键名参数集keys的个数,如果没有key的参数,就写0;
keys:键名参数集,通过全局变量KEYS数组表示,起始下标为1;
args:键值参数集,通过全局变量ARGV数组表示,起始下标为1;
2. Lua脚本调用redis命令
redis.call:在脚本中调用Redis命令,遇到错误会直接返回;
redis.log(loglevel,message):记录日志信息,日志级别为redis.LOG_DEBUG、redis.LOG_VERBOSE、redis.LOG_NOTICE、redis.LOG_WARNING;
3. 缓存Lua脚本
A. 缓存作用:在Lua脚本文件比较大的情况下,如果每次调用脚本都需要把整个脚本传给Redis服务端,会产生比较大的网络开销,因此需要Redis缓存Lua脚本并生成SHA1摘要码,后面直接通过摘要码来执行Lua脚本;
B. 生成摘要码:script load "......";
C. 通过摘要码执行缓存的脚本:evalsha "....." 0;
4. 参数
A. 脚本超时时间:lua-time-limit 5000;
可参考:Lua脚本入门