Lua 操作 Redis

雖然redis服務(wù)是單線程的服務(wù)驴剔,單步的redis操作是線程安全的届巩,但是當(dāng)我們?cè)诟卟l(fā)的情況下旱易,需要一系列的redis邏輯操作峦朗,而這些操作需要保證線程安全和原子性建丧。這時(shí)候就需要Lua登場。
Lua 為靜態(tài)語言提供更多的靈活性波势,Lua體積小翎朱、啟動(dòng)速度快。 Redis Lua 腳本出現(xiàn)之前 Redis 是沒有服務(wù)器端運(yùn)算能力的尺铣,主要是用來存儲(chǔ)拴曲,用做緩存,運(yùn)算是在客戶端進(jìn)行凛忿。有了 Lua 的支持澈灼,客戶端可以定義對(duì)鍵值的運(yùn)算,減少編譯的次數(shù),總之叁熔∥冢可以讓 Redis 更為靈活。redis 甚至在源代碼中加入了Lua腳本的解釋器荣回,eval遭贸。

redis 缺點(diǎn)

  1. 如此會(huì)破壞數(shù)據(jù)的一致性,試想如果兩個(gè)客戶端先后獲刃娜怼(get)一個(gè)值壕吹,它們分別對(duì)鍵值做不同的修改,然后先后提交結(jié)果糯累,最終 Redis 服務(wù)器中的結(jié)果肯定不是某一方客戶端所預(yù)期的算利。
  2. 浪費(fèi)了數(shù)據(jù)傳輸?shù)木W(wǎng)絡(luò)帶寬。

基本概念

1. Redis 2.6.0

  • 從Redis 2.6.0 開始泳姐, Redis在服務(wù)器端內(nèi)置Lua解釋器效拭,支持通過Lua腳本操作Redis

2. EVAL

  • 通過Lua操作Redis最常用的命令之一, 第一個(gè)參數(shù) Lua腳本

3. EVALSHA

  • 通過Lua操作Redis最常用的命令之一胖秒, 第一個(gè)參數(shù)是Lua腳本生成的SHA值缎患; 可以節(jié)省帶寬

4. 串行

  • Lua腳本在Redis服務(wù)器端是串行執(zhí)行的,因此可以實(shí)現(xiàn)類似事務(wù)的功能阎肝。

最簡單的Lua腳本

hello.lua

local msg = "hello world!"
return msg

運(yùn)行命令

redis-cli -h ****(ip) -p ***(port) eval "$(cat hello.lua)" 0

運(yùn)行這段代碼會(huì)打印"Hello,world!", EVAL在第一個(gè)參數(shù)是我們的lua腳本挤渔, 這我們用cat命令從文件中讀取我們的腳本內(nèi)容。第二個(gè)參數(shù)是這個(gè)腳本需要訪問的Redis 的鍵的數(shù)字號(hào)风题。我們簡單的 “Hello Script" 不會(huì)訪問任何鍵判导,所以我們使用 0

get和set 的例子

getSet.lua

local key = KEYS[1]
local value = ARGV[1]
redis.call('set', key, value)
return redis.call('get', key)

運(yùn)行命令

redis-cli -h ****(ip) -p ***(port) eval "$(cat getSet.lua)" 1 age 18
運(yùn)行結(jié)果.png

call() 的參數(shù)就是發(fā)給Redis的命令:首先set key value ,然后 get key,這兩個(gè)命令將依次執(zhí)行沛硅,當(dāng)這個(gè)腳本執(zhí)行時(shí)眼刃,Redis服務(wù)不會(huì)做任何操作(單線程),它將非骋〖。快速運(yùn)行擂红。

我們將會(huì)訪問兩個(gè)Lua表:KEYSARGV。表單是關(guān)聯(lián)性數(shù)組和結(jié)構(gòu)化數(shù)據(jù)的Lua唯一機(jī)制围小。對(duì)于我們的意圖昵骤,你可以把它們看做是一個(gè)你所熟悉的任意語言對(duì)等的數(shù)組,但是提醒兩個(gè)很容易困擾到新手的兩個(gè)Lua定則:
表是基于1的肯适,也就是說索引以數(shù)值1開始变秦。所以在表中的第一個(gè)元素就是KEYS[1],第二個(gè)就是KEY[2]等等框舔。
表中不能有nil值伴栓。如果一個(gè)操作表中有[1, nil, 3, 4],那么結(jié)果將會(huì)是[1]——表將會(huì)在第一個(gè)nil截?cái)唷?br> 當(dāng)調(diào)用這個(gè)腳本時(shí),我們還需要傳遞KEYSARGV表的值钳垮,為Redis編寫Lua腳本時(shí),每個(gè)KEY都是通過KEYS表指定额港。ARGV表用來傳遞參數(shù)饺窿。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市移斩,隨后出現(xiàn)的幾起案子肚医,更是在濱河造成了極大的恐慌,老刑警劉巖向瓷,帶你破解...
    沈念sama閱讀 219,366評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件肠套,死亡現(xiàn)場離奇詭異,居然都是意外死亡猖任,警方通過查閱死者的電腦和手機(jī)你稚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,521評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來朱躺,“玉大人刁赖,你說我怎么就攤上這事〕げ螅” “怎么了宇弛?”我有些...
    開封第一講書人閱讀 165,689評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長源请。 經(jīng)常有香客問我枪芒,道長,這世上最難降的妖魔是什么谁尸? 我笑而不...
    開封第一講書人閱讀 58,925評(píng)論 1 295
  • 正文 為了忘掉前任舅踪,我火速辦了婚禮,結(jié)果婚禮上症汹,老公的妹妹穿的比我還像新娘硫朦。我一直安慰自己,他們只是感情好背镇,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,942評(píng)論 6 392
  • 文/花漫 我一把揭開白布咬展。 她就那樣靜靜地躺著,像睡著了一般瞒斩。 火紅的嫁衣襯著肌膚如雪破婆。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,727評(píng)論 1 305
  • 那天胸囱,我揣著相機(jī)與錄音祷舀,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛裳扯,可吹牛的內(nèi)容都是我干的抛丽。 我是一名探鬼主播,決...
    沈念sama閱讀 40,447評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼饰豺,長吁一口氣:“原來是場噩夢啊……” “哼亿鲜!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起冤吨,我...
    開封第一講書人閱讀 39,349評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤蒿柳,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后漩蟆,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體垒探,經(jīng)...
    沈念sama閱讀 45,820評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,990評(píng)論 3 337
  • 正文 我和宋清朗相戀三年怠李,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了圾叼。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,127評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡扔仓,死狀恐怖褐奥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情翘簇,我是刑警寧澤撬码,帶...
    沈念sama閱讀 35,812評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站版保,受9級(jí)特大地震影響呜笑,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜彻犁,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,471評(píng)論 3 331
  • 文/蒙蒙 一叫胁、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧汞幢,春花似錦驼鹅、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,017評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至仲智,卻和暖如春买乃,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背钓辆。 一陣腳步聲響...
    開封第一講書人閱讀 33,142評(píng)論 1 272
  • 我被黑心中介騙來泰國打工剪验, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留肴焊,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,388評(píng)論 3 373
  • 正文 我出身青樓功戚,卻偏偏與公主長得像娶眷,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子疫铜,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,066評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容