Redis執(zhí)行Lua腳本的好處與示例代碼
前言
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)頻繁訪問頁面,需要記錄并檢測出來,就可以通過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ī)器上,如何測試這個(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。
測試運(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
補(bǔ)充:
現(xiàn)在Lua腳本用在很多游戲上,主要是Lua腳本做到可以嵌入到其他程序中運(yùn)行,游戲升級(jí)的時(shí)候,可以直接升級(jí)腳本,而不用重新安裝游戲。比如游戲的很多關(guān)卡,只需要增加lua腳本,在游戲中嵌入Lua解釋器,游戲團(tuán)隊(duì)線上更新Lua腳本,然后游戲自動(dòng)下載最新的游戲關(guān)卡。例如之前很多的游戲《憤怒的小鳥》就是用Lua語言實(shí)現(xiàn)的關(guān)卡。
摘自《Redis入門指南》
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
CentOS系統(tǒng)安裝Redis及Redis的PHP擴(kuò)展詳解
這篇文章主要介紹了CentOS系統(tǒng)下安裝Redis數(shù)據(jù)的教程,以及詳解了Redis數(shù)據(jù)庫的PHP擴(kuò)展,文中介紹的很詳細(xì),相信對(duì)大家的理解和學(xué)習(xí)具有一定的參考借鑒價(jià)值,有需要的朋友們可以參考借鑒,下面來一起看看吧。2016-12-12Redis面試必備之緩存設(shè)計(jì)規(guī)范與性能優(yōu)化詳解
你是否在使用Redis時(shí),不清楚Redis應(yīng)該遵循的設(shè)計(jì)規(guī)范而苦惱,你是否在Redis出現(xiàn)性能問題時(shí),不知道該如何優(yōu)化而發(fā)愁,快跟隨小編一起學(xué)習(xí)起來吧2024-03-03Redis數(shù)據(jù)結(jié)構(gòu)之鏈表詳解
大家好,本篇文章主要講的是Redis數(shù)據(jù)結(jié)構(gòu)之鏈表詳解,感興趣的同學(xué)趕快來看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12Redis 實(shí)現(xiàn)隊(duì)列原理的實(shí)例詳解
這篇文章主要介紹了Redis 實(shí)現(xiàn)隊(duì)列原理的實(shí)例詳解的相關(guān)資料,希望通過本文能幫助到大家,需要的朋友可以參考下2017-09-09CentOS 6.5 64位下安裝Redis3.0.2的具體步驟
這篇文章主要介紹了CentOS 6.5 64位下安裝Redis3.0.2的具體步驟,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-08-08超強(qiáng)、超詳細(xì)Redis數(shù)據(jù)庫入門教程
這篇文章主要介紹了超強(qiáng)、超詳細(xì)Redis入門教程,本文詳細(xì)介紹了Redis數(shù)據(jù)庫各個(gè)方面的知識(shí),需要的朋友可以參考下2014-10-10