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