Redis中缓存Lua 脚本
生活随笔
收集整理的這篇文章主要介紹了
Redis中缓存Lua 脚本
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
為什么要緩存
在腳本比較長的情況下,如果每次調(diào)用腳本都需要把整個(gè)腳本傳給Redis 服務(wù)端,會產(chǎn)生比較大的網(wǎng)絡(luò)開銷。為了解決這個(gè)問題,Redis 提供了EVALSHA 命令,允許開發(fā)者通過腳本內(nèi)容的SHA1 摘要來執(zhí)行腳本。
如何緩存
Redis 在執(zhí)行script load 命令時(shí)會計(jì)算腳本的SHA1 摘要并記錄在腳本緩存中,執(zhí)行EVALSHA 命令時(shí)Redis 會根據(jù)提供的摘要從腳本緩存中查找對應(yīng)的腳本內(nèi)容,如果找到了則執(zhí)行腳本,否則會返回錯(cuò)誤:"NOSCRIPT No matching script. Please use EVAL."
127.0.0.1:6379> script load "return 'Hello World'" "470877a599ac74fbfda41caa908de682c5fc7d4b" 127.0.0.1:6379> evalsha "470877a599ac74fbfda41caa908de682c5fc7d4b" 0 "Hello World"自乘案例
Redis 有incrby 這樣的自增命令,但是沒有自乘,比如乘以3,乘以5。
我們可以寫一個(gè)自乘的運(yùn)算,讓它乘以后面的參數(shù):
local curVal = redis.call("get", KEYS[1]) if curVal == false then curVal = 0 else curVal = tonumber(curVal) end curVal = curVal * tonumber(ARGV[1]) redis.call("set", KEYS[1], curVal) return curVal把這個(gè)腳本變成單行,語句之間使用分號隔開
local curVal = redis.call("get", KEYS[1]); if curVal == false then curVal = 0 else curVal = tonumber(curVal) end; curVal = curVal * tonumber(ARGV[1]); redis.call("set", KEYS[1], curVal); return curValscript load '命令'
127.0.0.1:6379> script load 'local curVal = redis.call("get", KEYS[1]); if curVal == false then curVal = 0 else curVal = tonumber(curVal) end; curVal = curVal * tonumber(ARGV[1]); redis.call("set", KEYS[1], curVal); return curVal' "be4f93d8a5379e5e5b768a74e77c8a4eb0434441" 調(diào)用: 127.0.0.1:6379> set num 2 OK 127.0.0.1:6379> evalsha be4f93d8a5379e5e5b768a74e77c8a4eb0434441 1 num 6 (integer) 12?
總結(jié)
以上是生活随笔為你收集整理的Redis中缓存Lua 脚本的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Redis中的Lua 脚本
- 下一篇: Redis中的Lua脚本超时