Redis支持使用Lua脚步来进行功能扩展,这个能力给Redis带来了更多的应用场景,你可以编写若干命令组合,作为一个小型的非阻塞事务或者更新逻辑
使用脚本的好处
Redis应用的使用方式很多都是 read-compute-write 模式,这需要客户端与服务端进行两次或者多次通信,而如果把中间的compute过程转移到服务端执行,则可以大幅地减少round-trip时间
将多个请求通过脚本的形式一次发送,减少网络时延
redis会将整个脚本作为一个整体执行,中间不会被其他命令插入,因此在编写脚本的过程中无需担心会出现竞态条件,无需使用事务
客户端发送的脚步会永久存在redis中,这样,其他客户端可以复用这一脚本而不需要使用代码完成相同的逻辑
Lua脚本示例
先实现一个简单脚本,仅仅返回一个字符串 代码 文件名 hello.lua
内容
local msg = "Hello, world!" return msg 执行 redis-cli EVAL "$(cat hello.lua)" 0 执行结果 "Hello, world!"
假设我们要实现一个URL简写功能,对存入的每条URL都返回一个唯一数值,以便以后通过这个数值访问到该URL 思路 使用INCR获得一个ID,以此ID为key,以url为值,存入hash表中 代码 文件名 url.lua 内容
local link_id = redis.call("INCR", "links:counter") redis.call("HSET", "links:urls", link_id, "http://test.com") return link_id 执行 src/redis-cli EVAL "$(cat url.lua)" 0 执行结果 "1" 验证 登录redis客户端 > hget links:urls 1 返回信息 "http://test.com"