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