日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
如何在Redis中執(zhí)行Lua腳本?

Redis中需要執(zhí)行Lua腳本的場景

Redis中每條命令都是原子性的,即執(zhí)行結(jié)果要么全部成功要么全部失敗。在某些業(yè)務(wù)場景下,需要執(zhí)行多條命令,并且要保證多條命令的原子性。這時,如果命令逐條執(zhí)行,顯然是不能保證原子性的。有同學(xué)可能會想到使用Redis的事務(wù)功能,事務(wù)是可以保證原子性,但是受限于命令的功能,有些場景下并不能實現(xiàn)想要的功能。

創(chuàng)新互聯(lián)公司專注于企業(yè)營銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、大豐網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、H5響應(yīng)式網(wǎng)站購物商城網(wǎng)站建設(shè)、集團公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為大豐等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

使用執(zhí)行Lua腳本的方式可以解決以上問題,Lua腳本整體上在Redis中是原子性的。

在Redis中執(zhí)行Lua腳本

在Redis中通過EVAL命令來執(zhí)行Lua腳本,基本語法如下:

redis 127.0.0.1:6379> EVAL script numkeys key [key ...] arg [arg ...]

參數(shù)說明:

  • script: 參數(shù)是一段Lua腳本程序。腳本不必(也不應(yīng)該)定義為一個 Lua 函數(shù)。
  • numkeys: 用于指定鍵名參數(shù)的個數(shù)。
  • key [key ...]: 從 EVAL 的第三個參數(shù)開始算起,表示在腳本中所用到的那些 Redis 鍵(key),這些鍵名參數(shù)可以在 Lua 中通過全局變量 KEYS 數(shù)組,用 1 為基址的形式訪問( KEYS[1] , KEYS[2] ,以此類推)。
  • arg [arg ...]: 附加參數(shù),在 Lua 中通過全局變量 ARGV 數(shù)組訪問,訪問的形式和 KEYS 變量類似( ARGV[1] 、 ARGV[2] ,諸如此類)。

獲取指定key的值,相當于于 GET somekey

EVAL "return redis.call('GET', KEYS[1])" 1 somekey

再看一個LPUSH的例子,相當于 LPUSH somelist 1 2 3

EVAL "return redis.call('LPUSH',KEYS[1], ARGV[1], ARGV[2], ARGV[3])" 1 somelist 1 2 3

簡單說下Redis執(zhí)行l(wèi)ua腳本相關(guān)的其他幾個命令:

  • EVALSHA命令根據(jù)給定的SHA1,執(zhí)行緩存在服務(wù)器中的腳本。
  • SCRIPT EXISTS命令用于檢查指定SHA1值對應(yīng)的腳本是否在Redis緩存中。
  • SCRIPT FLUSH命令用于清除所有的緩存腳本。
  • SCRIPT KILL命令用于殺死當前正在運行的 Lua 腳本,當且僅當這個腳本沒有執(zhí)行過任何寫操作時,這個命令才生效。這個命令主要用于終止運行時間過長的腳本,比如一個因為 BUG 而發(fā)生無限循環(huán)的腳本。SCRIPT KILL 執(zhí)行之后,當前正在運行的腳本會被殺死,執(zhí)行這個腳本的客戶端會從 EVAL 命令的阻塞當中退出,并收到一個錯誤作為返回值。

Lua腳本中調(diào)用Reids命令

調(diào)用Redis命令,當執(zhí)行出錯時,該方法會直接返回錯誤,并退出。

redis.call(redisCommand, key, argv...)

調(diào)用Redis命令,當執(zhí)行出錯時,記錄錯誤信息,并繼續(xù)執(zhí)行。

redis.pcall(redisCommand, key, argv...)

記錄日志,寫入到Redis配置的日志文件中,日志級別有四種,分別是redis.LOG_DEBUG、redis.LOG_VERBOS、redis.LOG_NOTICE和redis.LOG_WARNING。

redis.log(logLevel, message)

計算輸入字符串的sha1哈希值。

redis.sha1hex(arvg)

Lua與Redis類型轉(zhuǎn)換

Redis調(diào)用Lua腳本,腳本執(zhí)行完成后將結(jié)果返回給Redis,Redis再將結(jié)果返回給客戶端。這個過程中會出現(xiàn)Redis執(zhí)行結(jié)果類型到Lua數(shù)據(jù)類型的轉(zhuǎn)換,然后Lua類型到Redis類型的轉(zhuǎn)換。Redis類型到Lua類型轉(zhuǎn)換關(guān)系如下:

Redis返回的數(shù)據(jù)類型

Lua數(shù)據(jù)類型

integer(整數(shù)回復(fù))

number(數(shù)字類型)

bulk replay(字符串)

string(字符串類型)

多行字符串

table(數(shù)組形式)

status(狀態(tài)回復(fù))

table(只有一個ok字段的數(shù)組)

error(錯誤回復(fù))

table(只有一個err字段的數(shù)組)

Lua類型到Redis類型轉(zhuǎn)換關(guān)系如下:

Lua數(shù)據(jù)類型

Redis返回數(shù)據(jù)類型

number(數(shù)字類型)

integer(整數(shù)回復(fù))

string(字符串類型)

bulk replay(字符串)

table(數(shù)組形式)

多行字符串

table(只有一個ok字段的數(shù)組)

status(狀態(tài)回復(fù))

table(只有一個err字段的數(shù)組)

error(錯誤回復(fù))


名稱欄目:如何在Redis中執(zhí)行Lua腳本?
轉(zhuǎn)載來于:http://www.dlmjj.cn/article/djojhsc.html