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脚本入门

    Lua脚本开发

 

posted @ 2021-11-18 11:58  如幻行云  阅读(776)  评论(0编辑  收藏  举报