Redis和lua整合

Redis中使⽤lua的好处

1、减少⽹络开销,在Lua脚本中可以把多个命令放在同⼀个脚本中运⾏
2、原⼦操作,redis会将整个脚本作为⼀个整体执⾏,中间不会被其他命令插⼊。换句话说,编写脚本
的过程中⽆需担⼼会出现竞态条件
3、复⽤性,客户端发送的脚本会永远存储在redis中,这意味着其他客户端可以复⽤这⼀脚本来完成同
样的逻辑

lua的安装

  1. 下载:
    地址:http://www.lua.org/download.html
    可以本地下载上传到linux,也可以使⽤curl命令在linux系统中进⾏在线下载
    curl -R -O http://www.lua.org/ftp/lua-5.3.5.tar.gz
  2. 安装:
    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的控制台
  3. Redis整合lua脚本:
    从Redis2.6.0版本开始,通过内置的lua编译/解释器,可以使⽤EVAL命令对lua脚本进⾏求值。
  4. 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] ,诸如此类)。
  5. lua脚本中调⽤Redis命令:
    redis.call():
    返回值就是redis命令执⾏的返回值
    如果出错,则返回错误信息,不继续执⾏
    redis.pcall():
    返回值就是redis命令执⾏的返回值
    如果出错,则记录错误信息,继续执⾏
    注意事项
    在脚本中,使⽤return语句将返回值返回给客户端,如果没有return,则返回nil
    eval “return redis.call(‘set’,KEYS[1],ARGV[1])” 1 n1 zhaoyun
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值