您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關(guān)redis中怎么使用lua腳本的內(nèi)容。小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過(guò)來(lái)看看吧。
一:Lua腳本
說(shuō)來(lái)也巧,redis的大老板給了你解決這種問(wèn)題的方法,那就是Lua腳本,而且redis的最新版本也支持Lua Script debug,這應(yīng)該也是未來(lái)Redis的一
個(gè)發(fā)展趨勢(shì),要想學(xué)好Redis,必會(huì)Lua Script。。。
有趣的是,官網(wǎng)上還提供了一個(gè)視頻教程教你如何進(jìn)行Debug操作。。。 【https://redis.io/topics/ldb】 youtube上面的視頻,要是被墻了,記得
上VPN哦。。。淘寶上不知道有沒(méi)有售賣(mài)這種同款的吸頂燈~(yú)~~
二:使用Redis-Cli Lua Script 解決幾個(gè)靈活性問(wèn)題
1. Lua語(yǔ)法的問(wèn)題
lua是一門(mén)編程語(yǔ)言,所以這個(gè)就已經(jīng)超出了redis本身的范疇,如果大家想好好學(xué)習(xí)一下,可以看下http://www.lua.org/ 的官網(wǎng),然后下載一下玩一玩。
比如這里我下載了一個(gè)windows版本的lua 編譯器,具體語(yǔ)法上就不細(xì)說(shuō)了。。有了這個(gè)主題,我們?cè)龠M(jìn)行下一個(gè)環(huán)節(jié)。
2. Eval的使用
EVAL script numkeys key [key ...] arg [arg ...]
首先大家一定要知道eval的語(yǔ)法格式,其中:
<1> script: 你的lua腳本
<2> numkeys: key的個(gè)數(shù)
<3> key: redis中各種數(shù)據(jù)結(jié)構(gòu)的替代符號(hào)
<4> arg: 你的自定義參數(shù)
ok,可能乍一看模板不是特別清楚,下面我可以用官網(wǎng)的小案例演示一下:
eval "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 username age jack 20
上面這一串代碼大概是什么意思呢? 第一個(gè)參數(shù)的字符串就是script,也就是lua腳本。2表示keys的個(gè)數(shù),KEYS[1] 就是 username的占位符, KEYS[2]就是
age的占位符,ARGV[1]就是jack的占位符,ARGV[2]就是20的占位符,,以此類(lèi)推,,,所以最后的結(jié)果應(yīng)該就是:{return username age jack 20} 是不
是有點(diǎn)像C#中的占位符:{0}呢???下面我在Redis中給大家演示一下:
[root@localhost Desktop]# redis-cli 127.0.0.1:6379> eval "return {KEYS[1],KEYS[2],ARGV[1],ARGV[2]}" 2 username age jack 20 1) "username" 2) "age" 3) "jack" 4) "20" 127.0.0.1:6379>
通常境況下,我們不要在redis-cli中直接寫(xiě)lua腳本,這樣非常不方便編輯,通常情況下我們都是把lua script放到一個(gè)lua文件中,然后執(zhí)行這個(gè)lua腳本,比如
下面這樣:
然后我們通過(guò)下面命令執(zhí)行,這種方式和前面介紹的不一樣,參數(shù) --eval script key1 key2 , arg1 age2 這種模式,key和value用一個(gè)逗號(hào)隔開(kāi)就好了,
最后我們也看到了,數(shù)據(jù)都出來(lái)了,對(duì)吧。
[root@localhost Desktop]# redis-cli --eval /usr/redis/sbin/1.lua username age , jack 20 1) "username" 2) "age" 3) "jack" 4) "20" [root@localhost Desktop]#
三:實(shí)戰(zhàn)
下面我可以構(gòu)思幾個(gè)小案例通過(guò)lua解決。
1. 通過(guò)lua腳本獲取指定的key的List中的所有數(shù)據(jù)
local key=KEYS[1] local list=redis.call("lrange",key,0,-1); return list;
這里面的redis.call就是用來(lái)執(zhí)行redis中l(wèi)ist的lrange命令,接下來(lái)我通過(guò)lpush給person塞入三條數(shù)據(jù),如下:
[root@localhost Desktop]# redis-cli 127.0.0.1:6379> lpush person mary jack peter (integer) 3 127.0.0.1:6379>
然后我們來(lái)執(zhí)行這個(gè)lua腳本,效果如下圖,是不是很牛逼的感覺(jué)???
有了這個(gè)1+1的效果,就可以玩些更復(fù)雜的操作。比如:
2.根據(jù)外面?zhèn)鬟^(guò)來(lái)的IDList 做“集合去重”的lua腳本邏輯:
local key=KEYS[1]; local args=ARGV local i=0; local result={}; for m,n in ipairs(args) do local ishit=redis.call("sismember",key,n); if(ishit) then table.insert(result,1,n); end end return result;
2. 找到hash中age小于指定值的所有數(shù)據(jù),lua腳本如下:
local result={}; local myperson=KEYS[1]; local nums=ARGV[1]; local myresult =redis.call("hkeys",myperson); for i,v in ipairs(myresult) do local hval= redis.call("hget",myperson,v); redis.log(redis.LOG_WARNING,hval); if(tonumber(hval)<tonumber(nums)) then table.insert(result,1,v); end end return result;
感謝各位的閱讀!關(guān)于“redis中怎么使用lua腳本”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。