redis命令行执行lua脚本


大家都知道:在Redis中执行的每条命令都能保证其原子性,但是如何保证多条原生命令执行的原子性呢?这时候Redis为这样的用户场景提供了 lua 脚本支持,用户可以向服务器发送 lua 脚本来执行自定义动作,获取脚本的响应数据。Redis 服务器会单线程原子性执行 lua 脚本,保证 lua 脚本在处理的过程中不会被任意其它请求打断。


  1. 常用命令

    1.1 EVAL script numkeys key [key ...] arg [arg ...]  

          numkeys 是key的个数,后边接着写key1 key2...  val1 val2....,示例:

    127.0.0.1:6379> eval "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 key1 key2 val1 val2
    1) "key1"
    2) "key2"
    3) "val1"
    4) "val2"

    1.2 SCRIPT LOAD script
          把脚本加载到脚本缓存中,返回SHA1校验值。但不会立马执行,示例:

    127.0.0.1:6379> SCRIPT LOAD "return 'hello world'"
    "5332031c6b470dc5a0dd9b4bf2030dea6d65de91"

    1.3 EVALSHA sha1 numkeys key [key ...] arg [arg ...] 
          根据sha1值执行脚本内容,示例:
     

    127.0.0.1:6379> SCRIPT LOAD "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 
    "a42059b356c875f0717db19a51f6aaca9ae659ea"
    127.0.0.1:6379> EVALSHA "a42059b356c875f0717db19a51f6aaca9ae659ea" 2 key1 key2 val1 val2
    1) "key1"
    2) "key2"
    3) "val1"
    4) "val2"

    1.4 SCRIPT EXISTS sha1 [sha1 ...] 
          根据sha1校验值判断脚本是否在缓存中,示例:

    127.0.0.1:6379> SCRIPT LOAD "return 'hello world'"
    "5332031c6b470dc5a0dd9b4bf2030dea6d65de91"
    127.0.0.1:6379> SCRIPT EXISTS 5332031c6b470dc5a0dd9b4bf2030dea6d65de91
    1) (integer) 1

    1.5  SCRIPT FLUSH
           清除Redis服务端所有 Lua 脚本缓存,示例:

    127.0.0.1:6379> script flush
    OK

    1.6 SCRIPT KILL 
          杀死目前正在运行的脚本

  2. 执行lua脚本 

    命令: redis-cli -a 密码 --eval Lua脚本路径 key [key …] , arg [arg …] 
    注意:英文逗号前后必须要要有个空格,否则执行会报错
    示例:

    root@hub2-8:/home# redis-cli -a xxxxx--eval demo.lua key1 key2 , val1 val2
    (nil)

     

你可能感兴趣的:(redis,lua,redis,lua,缓存)