美文网首页
redis 的lua脚本

redis 的lua脚本

作者: lionel880 | 来源:发表于2019-05-28 11:21 被阅读0次

    参考redis写分布式竞争一个锁的时候,碰到了lua脚本的问题,引出学习一下
    参考文档:
    redis.io
    https://wudashan.cn/2017/10/23/Redis-Distributed-Lock-Implement/

    由于涉及到lua脚本,所以又简单学习了一下 redis的lua脚本
    参考文档:http://redisdoc.com/script/eval.html
    Lua: 给 Redis 用户的入门指导

    一、为什么要用脚本

    减少网络开销。可以将多个请求通过脚本的形式一次发送,减少网络时延
    原子操作。redis会将整个脚本作为一个整体执行,中间不会被其他命令插入。因此在编写脚本的过程中无需担心会出现竞态条件,无需使用事务。
    复用。客户端发送的脚步会永久存在redis中,这样,其他客户端可以复用这一脚本而不需要使用代码完成相同的逻辑。

    二、如何使用脚本

    这里的重点是关于 keys和argv的理解,因为所有的网站举例都是

    • script : 参数是一段 Lua 5.1 脚本程序。脚本不必(也不应该)定义为一个 Lua 函数。
    • numkeys : 用于指定键名参数的个数。
    • key [key ...] : 从 EVAL 的第三个参数开始算起,表示在脚本中所用到的那些 Redis 键(key),这些键名参数可以在 Lua 中通过全局变量 KEYS 数组,用 1 为基址的形式访问( KEYS[1] , KEYS[2] ,以此类推)。
    • arg [arg ...] : 附加参数,在 Lua 中通过全局变量 ARGV 数组访问,访问的形式和 KEYS 变量类似( ARGV[1] 、 ARGV[2] ,诸如此类)。
    格式:
    redis 127.0.0.1:6379> EVAL script numkeys key [key ...] arg [arg ...]
    举例:
    redis 127.0.0.1:6379> eval "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 first second 
    1) "key1" 
    2) "key2"
     3) "first" 
    4) "second"
    

    这个举例其实完全看不出KEYS和ARGV参数的区别,明明一个是实际的键名,一个是附属的参数,换个例子就很好理解

    redis>EVAL "return redis.call('SET', KEYS[1], ARGV[1])" 1 foo bar
    OK
    redis>GET foo
    "bar"
    
    • redis lua 脚本所有的键都应该用keys传递

    相关文章

      网友评论

          本文标题:redis 的lua脚本

          本文链接:https://www.haomeiwen.com/subject/mvzeiftx.html