今天就跟大家聊聊有關(guān)redis中如何執(zhí)行Lua腳本,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
目前成都創(chuàng)新互聯(lián)公司已為上1000家的企業(yè)提供了網(wǎng)站建設(shè)、域名、虛擬空間、網(wǎng)站托管、服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計(jì)、上街網(wǎng)站維護(hù)等服務(wù),公司將堅(jiān)持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
前言
Redis從2.6版本開始引入對(duì)Lua腳本的支持,通過在服務(wù)器中嵌入Lua環(huán)境,Redis客戶端可以使用Lua腳本,直接在服務(wù)端原子的執(zhí)行多個(gè)Redis命令。
其中,使用EVAL命令可以直接對(duì)輸入的腳本進(jìn)行求值:
redis>EVAL "return 'hello world'" 0 "hello world"
使用腳本的好處如下:
1.減少網(wǎng)絡(luò)開銷:本來5次網(wǎng)絡(luò)請(qǐng)求的操作,可以用一個(gè)請(qǐng)求完成,原先5次請(qǐng)求的邏輯放在redis服務(wù)器上完成。使用腳本,減少了網(wǎng)絡(luò)往返時(shí)延。
2.原子操作:Redis會(huì)將整個(gè)腳本作為一個(gè)整體執(zhí)行,中間不會(huì)被其他命令插入。
3.復(fù)用:客戶端發(fā)送的腳本會(huì)永久存儲(chǔ)在Redis中,意味著其他客戶端可以復(fù)用這一腳本而不需要使用代碼完成同樣的邏輯。
Redis執(zhí)行Lua腳本
實(shí)現(xiàn)一個(gè)訪問頻率控制,某個(gè)ip在短時(shí)間內(nèi)頻繁訪問頁面,需要記錄并檢測(cè)出來,就可以通過Lua腳本高效的實(shí)現(xiàn)
在redis客戶端機(jī)器上,新建一個(gè)文件ratelimiting.lua,內(nèi)容如下
local times = redis.call('incr',KEYS[1]) if times == 1 then redis.call('expire',KEYS[1], ARGV[1]) end if times > tonumber(ARGV[2]) then return 0 end return 1
在redis客戶端機(jī)器上,如何測(cè)試這個(gè)腳本呢?如下:
redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3
--eval參數(shù)是告訴redis-cli讀取并運(yùn)行后面的Lua腳本,ratelimiting.lua是腳本的位置,后面跟著是傳給Lua腳本的參數(shù)。其中","前的rate.limiting:127.0.0.1是要操作的鍵,可以再腳本中用KEYS[1]獲取,","后面的10和3是參數(shù),在腳本中能夠使用ARGV[1]和ARGV[2]獲得。注:","兩邊的空格不能省略,否則會(huì)出錯(cuò)
結(jié)合腳本的內(nèi)容可知這行命令的作用是將訪問頻率限制為每10秒最多3次,所以在終端中不斷的運(yùn)行此命令會(huì)發(fā)現(xiàn)當(dāng)訪問頻率在10秒內(nèi)小于或等于3次時(shí)返回1,否則返回0。
測(cè)試運(yùn)行如下:
[root@rhel6 redis-learning]# redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3 (integer) 1 [root@rhel6 redis-learning]# redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3 (integer) 1 [root@rhel6 redis-learning]# redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3 (integer) 1 [root@rhel6 redis-learning]# redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3 (integer) 0 [root@rhel6 redis-learning]# redis-cli --eval ratelimiting.lua rate.limitingl:127.0.0.1 , 10 3 (integer) 0
看完上述內(nèi)容,你們對(duì)Redis中如何執(zhí)行Lua腳本有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。
文章標(biāo)題:Redis中如何執(zhí)行Lua腳本
本文網(wǎng)址:http://chinadenli.net/article32/ppcepc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計(jì)、網(wǎng)站排名、服務(wù)器托管、網(wǎng)站設(shè)計(jì)公司、品牌網(wǎng)站設(shè)計(jì)、微信公眾號(hào)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)