亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Redis使用Lua腳本命令詳解

 更新時間:2023年12月05日 11:00:54   作者:bug生產(chǎn)者  
這篇文章主要為大家介紹了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)文章!

相關(guān)文章

  • redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法

    redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法

    這篇文章主要為大家詳細(xì)介紹了redis緩存數(shù)據(jù)庫中數(shù)據(jù)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 使用Redis實現(xiàn)UA池的方案

    使用Redis實現(xiàn)UA池的方案

    這篇文章主要介紹了使用Redis實現(xiàn)UA池的方案,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-11-11
  • redis加鎖的三種方式小結(jié)

    redis加鎖的三種方式小結(jié)

    本文主要介紹了redis加鎖的三種方式小結(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • redis 用scan指令 代替keys指令(詳解)

    redis 用scan指令 代替keys指令(詳解)

    下面小編就為大家分享一篇redis 用scan指令 代替keys指令詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • Redis內(nèi)存碎片產(chǎn)生原因及Pipeline管道原理解析

    Redis內(nèi)存碎片產(chǎn)生原因及Pipeline管道原理解析

    這篇文章主要為大家介紹了Redis內(nèi)存碎片產(chǎn)生原因及Pipeline管道原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • Redis中的數(shù)據(jù)結(jié)構(gòu)跳表詳解

    Redis中的數(shù)據(jù)結(jié)構(gòu)跳表詳解

    跳表是一種基于并聯(lián)的鏈表結(jié)構(gòu),用于在有序元素序列中快速查找元素的數(shù)據(jù)結(jié)構(gòu),本文給大家介紹Redis中的數(shù)據(jù)結(jié)構(gòu)跳表,感興趣的朋友跟隨小編一起看看吧
    2024-06-06
  • Redis數(shù)據(jù)結(jié)構(gòu)之跳躍表使用學(xué)習(xí)

    Redis數(shù)據(jù)結(jié)構(gòu)之跳躍表使用學(xué)習(xí)

    這篇文章主要為大家介紹了Redis數(shù)據(jù)結(jié)構(gòu)之跳躍表使用學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • Redis集群指定主從關(guān)系及動態(tài)增刪節(jié)點方式

    Redis集群指定主從關(guān)系及動態(tài)增刪節(jié)點方式

    這篇文章主要介紹了Redis集群指定主從關(guān)系及動態(tài)增刪節(jié)點方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Redis緩存高可用集群詳解

    Redis緩存高可用集群詳解

    Redis集群提供了哨兵模式和高可用集群模式兩種方案,前者適合低并發(fā),配置復(fù)雜,主從切換可能導(dǎo)致瞬斷;后者通過多主多從結(jié)構(gòu)提高可用性和性能,支持線性擴展,配置簡單,搭建Redis集群至少需要三個主節(jié)點
    2024-10-10
  • Redis集群的關(guān)閉與重啟操作

    Redis集群的關(guān)閉與重啟操作

    這篇文章主要介紹了Redis集群的關(guān)閉與重啟操作,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07

最新評論