Redis中使⽤lua的好处
1、减少⽹络开销,在Lua脚本中可以把多个命令放在同⼀个脚本中运⾏
2、原⼦操作,redis会将整个脚本作为⼀个整体执⾏,中间不会被其他命令插⼊。换句话说,编写脚本
的过程中⽆需担⼼会出现竞态条件
3、复⽤性,客户端发送的脚本会永远存储在redis中,这意味着其他客户端可以复⽤这⼀脚本来完成同
样的逻辑
lua的安装
- 下载:
地址:http://www.lua.org/download.html
可以本地下载上传到linux,也可以使⽤curl命令在linux系统中进⾏在线下载
curl -R -O http://www.lua.org/ftp/lua-5.3.5.tar.gz - 安装:
yum -y install readline-devel ncurses-devel
tar -zxvf lua-5.3.5.tar.gz
make linux
make install
如果报错,说找不到readline/readline.h, 可以通过yum命令安装
安装完以后再
最后,直接输⼊ lua命令即可进⼊lua的控制台 - Redis整合lua脚本:
从Redis2.6.0版本开始,通过内置的lua编译/解释器,可以使⽤EVAL命令对lua脚本进⾏求值。 - Redis命令⾏:
EVAL script numkeys key [key …] arg [arg …]
命令说明:
script参数:是⼀段Lua脚本程序,它会被运⾏在Redis服务器上下⽂中,这段脚本不必(也不应该)
定义为⼀个Lua函数。
numkeys参数:⽤于指定键名参数的个数。
key [key …]参数: 从EVAL的第三个参数开始算起,使⽤了numkeys个键(key),表示在脚本中所⽤到的那些Redis键(key),这些键名参数可以在Lua中通过全局变量KEYS数组,⽤1为基址的形式访问( KEYS[1] , KEYS[2] ,以此类推)。
arg [arg …]参数:可以在Lua中通过全局变量ARGV数组访问,访问的形式和KEYS变量类似(ARGV[1] 、 ARGV[2] ,诸如此类)。 - lua脚本中调⽤Redis命令:
redis.call():
返回值就是redis命令执⾏的返回值
如果出错,则返回错误信息,不继续执⾏
redis.pcall():
返回值就是redis命令执⾏的返回值
如果出错,则记录错误信息,继续执⾏
注意事项
在脚本中,使⽤return语句将返回值返回给客户端,如果没有return,则返回nil
eval “return redis.call(‘set’,KEYS[1],ARGV[1])” 1 n1 zhaoyun