Redis使用Lua腳本命令詳解
Lua腳本
redis可以支持lua腳本,可以使用lua腳本來將幾個命令整合為一個整體來執(zhí)行,這樣可以使得多個命令原子操作,且可以減少網(wǎng)絡(luò)開銷
Lua的數(shù)據(jù)類型
Lua是一個動態(tài)類型的語言,一個變量可以存儲任何類型的值,類型有:
- 空:nil,也就是還沒有賦值
- 字符串:用單引號 或者 雙引號
- 數(shù)字:包含整數(shù)和浮點型
- 布爾:boolean
- 表:表是Lua唯一的數(shù)據(jù)結(jié)構(gòu),既可以當(dāng)數(shù)組,也可以做Map,或被視為對象
- 函數(shù):封裝某個或某些功能
- userData:用來將任意 C 數(shù)據(jù)保存在 Lua 變量中,這樣的操作只能通過 C API
- Thread:用來區(qū)別獨立的執(zhí)行線程,它被用來實現(xiàn) coroutine (協(xié)同例程)
eval命令
redis內(nèi)有內(nèi)置的lua解釋器,可以使用eval命令對lua腳本進行求值
# script是lua腳本 # numkeys指定鍵名參數(shù)的個數(shù) # key [key ...] 在腳本中使用的redis鍵,個數(shù)為numkeys指定的個數(shù),可以在lua中通過全局變量KEYS數(shù)組,從1開始,KEYS[1],KEYS[2]等 # arg [arg ...] 參數(shù),可以在lua中通過全局變量ARGV數(shù)組訪問,ARGV[1],ARGV[2]等 eval script numkeys key [key ...] arg [arg ...] #示例: eval "return {KEYS[1],KEYS[2],ARGV[1]}" 2 key1 key2 first
還可以在lua腳本中調(diào)用redis命令,使用redis.call
eval "return redis.call('set',KEYS[1],'bar')" 1 foo
需要注意的是,redis執(zhí)行l(wèi)ua腳本和普通命令一樣,都是會寫入AOF文件和發(fā)布至主從復(fù)制連接上的,有兩種方式
第一種方式:和普通命令相同,涉及到的寫操作都會記錄/發(fā)送
普通命令會轉(zhuǎn)化為redis通信協(xié)議的格式,比起lua腳本來說,浪費了更多的帶寬,而且slave接收到之后還需要再轉(zhuǎn)換為普通命令
第二種方式:直接將lua腳本記錄/發(fā)送
如果直接發(fā)送lua腳本,有些命令可能會導(dǎo)致每個機器執(zhí)行的結(jié)果不同,如取隨機數(shù)等
這個redis會決定采取哪種方式來執(zhí)行,在執(zhí)行前會進行檢測寫操作是否執(zhí)行了RANDOMKEY命令,來決定使用哪種方式
evalsha命令
考慮到腳本比較長的情況,如果每次調(diào)用腳本都需要將整個腳本傳給redis會占用較多的帶寬。為了解決該問題,redis提供了evalsha命令允許開發(fā)者通過腳本內(nèi)容的SHA1摘要來執(zhí)行腳本,該命令的用法的eval一樣,不過是將腳本內(nèi)容替換為腳本內(nèi)容的SHA1摘要。
redis在執(zhí)行eval命令時會計算腳本的SHA1摘要并記錄在腳本緩存中,執(zhí)行evalsha命令時redis會根據(jù)提供的摘要從腳本緩存中查找對應(yīng)的腳本內(nèi)容,如果找到了則執(zhí)行腳本,否則返回錯誤
使用流程
- 先計算腳本的SHA1摘要,并使用evalsha命令執(zhí)行腳本
- 獲的返回值,如果返回"NoScript"錯誤則使用eval命令重新執(zhí)行腳本
其他不常用的命令
這些命令不是不常用,而是經(jīng)常被工具類封裝起來,開發(fā)者如果不深入源碼查看,很少會用到
將腳本加入緩存
SCRIPT LOAD命令,作用是每次執(zhí)行eval命令時redis都會將腳本的SHA1摘要加入到腳本緩存中,以便下次客戶端可以使用evalsha命令調(diào)用該腳本。如果只是希望將腳本加入緩存而不執(zhí)行,則使用SCRIPT LOAD命令,返回值是腳本的SHA1摘要
判斷腳本是否被緩存
SCRIPT EXISTS命令,可以同時查找多個腳本的SHA1摘要是否被緩存
清空腳本緩存
SCRIPT FLUSH命令,redis將腳本的SHA1摘要加入到腳本緩存后會永久保留,不會刪除,可以使用該命令清空腳本緩存
強制終止當(dāng)前腳本的執(zhí)行
SCRIPT KILL命令,如果想終止當(dāng)前正在執(zhí)行的腳本可以使用該命令
以上就是Redis使用Lua腳本命令詳解的詳細(xì)內(nèi)容,更多關(guān)于Redis使用Lua腳本的資料請關(guān)注腳本之家其它相關(guān)文章!
- redis lua腳本實戰(zhàn)秒殺和減庫存的實現(xiàn)
- Redis中Lua腳本的使用和設(shè)置超時
- Redis+Lua腳本實現(xiàn)計數(shù)器接口防刷功能(升級版)
- springboot使用redisTemplate操作lua腳本
- Java生態(tài)/Redis中使用Lua腳本的過程
- Redis中l(wèi)ua腳本實現(xiàn)及其應(yīng)用場景
- redis使用Lua腳本解決多線程下的超賣問題及原因解析
- redis?lua腳本解決高并發(fā)下秒殺場景
- Redis結(jié)合Lua腳本實現(xiàn)分布式鎖詳解
- Redis Lua腳本的使用教程
- Redis整合Lua腳本的實現(xiàn)操作
相關(guān)文章
redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法
這篇文章主要為大家詳細(xì)介紹了redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-07-07Redis內(nèi)存碎片產(chǎn)生原因及Pipeline管道原理解析
這篇文章主要為大家介紹了Redis內(nèi)存碎片產(chǎn)生原因及Pipeline管道原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-03-03Redis中的數(shù)據(jù)結(jié)構(gòu)跳表詳解
跳表是一種基于并聯(lián)的鏈表結(jié)構(gòu),用于在有序元素序列中快速查找元素的數(shù)據(jù)結(jié)構(gòu),本文給大家介紹Redis中的數(shù)據(jù)結(jié)構(gòu)跳表,感興趣的朋友跟隨小編一起看看吧2024-06-06Redis數(shù)據(jù)結(jié)構(gòu)之跳躍表使用學(xué)習(xí)
這篇文章主要為大家介紹了Redis數(shù)據(jù)結(jié)構(gòu)之跳躍表使用學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07Redis集群指定主從關(guān)系及動態(tài)增刪節(jié)點方式
這篇文章主要介紹了Redis集群指定主從關(guān)系及動態(tài)增刪節(jié)點方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-01-01