Redis 中的 Lua 脚本可以让你执行一系列 Redis 命令,而这些命令将作为单个操作原子执行。这就意味着在 Lua 脚本执行期间,其他的 Redis 客户端无法执行任何命令。
Lua 脚本的主要优势是它可以减少网络开销,因为它只需要一次网络往返时间(RTT)就可以执行多个命令。
以下是一些使用 Redis Lua 脚本的方法:
- 使用 EVAL 命令执行 Lua 脚本:
EVAL script numkeys key [key ...] arg [arg ...]
例如,以下命令将 Lua 脚本作为参数执行。
redis-cli EVAL "return redis.call('set', KEYS[1], ARGV[1])" 1 mykey myvalue
- 使用 EVALSHA 命令执行 Lua 脚本:
EVALSHA sha1 numkeys key [key ...] arg [arg ...]
首先,你需要使用 SCRIPT LOAD 命令将 Lua 脚本加载到 Redis 服务器中,然后使用生成的 sha1 哈希运行脚本。
redis-cli SCRIPT LOAD "return redis.call('set', KEYS[1], ARGV[1])"
# 假设返回的 sha1 是 "34b43e4c0ffc3ad6f35c08297163e36d521426cd"
redis-cli EVALSHA 34b43e4c0ffc3ad6f35c08297163e36d521426cd 1 mykey myvalue
- 使用 Redis Lua 脚本进行事务操作:
redis-cli --pipe-mode
在 pipe-mode 中,你可以将多个命令发送到 Redis,并且这些命令将作为单个事务执行。
redis-cli --pipe-mode < /path/to/commands.txt
其中,commands.txt 文件包含要执行的 Redis 命令,例如:
SET mykey "Hello"
SADD myset "Hello"
以上就是 Redis Lua 脚本的基本使用方法。