掃二維碼與項(xiàng)目經(jīng)理溝通
我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢(xún)/運(yùn)營(yíng)咨詢(xún)/技術(shù)建議/互聯(lián)網(wǎng)交流
Redis中每條命令都是原子性的,即執(zhí)行結(jié)果要么全部成功要么全部失敗。在某些業(yè)務(wù)場(chǎng)景下,需要執(zhí)行多條命令,并且要保證多條命令的原子性。這時(shí),如果命令逐條執(zhí)行,顯然是不能保證原子性的。有同學(xué)可能會(huì)想到使用Redis的事務(wù)功能,事務(wù)是可以保證原子性,但是受限于命令的功能,有些場(chǎng)景下并不能實(shí)現(xiàn)想要的功能。

創(chuàng)新互聯(lián)公司專(zhuān)注于企業(yè)營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、網(wǎng)站重做改版、大豐網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5響應(yīng)式網(wǎng)站、購(gòu)物商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性?xún)r(jià)比高,為大豐等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。
使用執(zhí)行Lua腳本的方式可以解決以上問(wèn)題,Lua腳本整體上在Redis中是原子性的。
在Redis中通過(guò)EVAL命令來(lái)執(zhí)行Lua腳本,基本語(yǔ)法如下:
redis 127.0.0.1:6379> EVAL script numkeys key [key ...] arg [arg ...]
參數(shù)說(shuō)明:
獲取指定key的值,相當(dāng)于于 GET somekey
EVAL "return redis.call('GET', KEYS[1])" 1 somekey再看一個(gè)LPUSH的例子,相當(dāng)于 LPUSH somelist 1 2 3
EVAL "return redis.call('LPUSH',KEYS[1], ARGV[1], ARGV[2], ARGV[3])" 1 somelist 1 2 3簡(jiǎn)單說(shuō)下Redis執(zhí)行l(wèi)ua腳本相關(guān)的其他幾個(gè)命令:
調(diào)用Redis命令,當(dāng)執(zhí)行出錯(cuò)時(shí),該方法會(huì)直接返回錯(cuò)誤,并退出。
redis.call(redisCommand, key, argv...)
調(diào)用Redis命令,當(dāng)執(zhí)行出錯(cuò)時(shí),記錄錯(cuò)誤信息,并繼續(xù)執(zhí)行。
redis.pcall(redisCommand, key, argv...)
記錄日志,寫(xiě)入到Redis配置的日志文件中,日志級(jí)別有四種,分別是redis.LOG_DEBUG、redis.LOG_VERBOS、redis.LOG_NOTICE和redis.LOG_WARNING。
redis.log(logLevel, message)
計(jì)算輸入字符串的sha1哈希值。
redis.sha1hex(arvg)
Redis調(diào)用Lua腳本,腳本執(zhí)行完成后將結(jié)果返回給Redis,Redis再將結(jié)果返回給客戶(hù)端。這個(gè)過(guò)程中會(huì)出現(xiàn)Redis執(zhí)行結(jié)果類(lèi)型到Lua數(shù)據(jù)類(lèi)型的轉(zhuǎn)換,然后Lua類(lèi)型到Redis類(lèi)型的轉(zhuǎn)換。Redis類(lèi)型到Lua類(lèi)型轉(zhuǎn)換關(guān)系如下:
|
Redis返回的數(shù)據(jù)類(lèi)型 |
Lua數(shù)據(jù)類(lèi)型 |
|
integer(整數(shù)回復(fù)) |
number(數(shù)字類(lèi)型) |
|
bulk replay(字符串) |
string(字符串類(lèi)型) |
|
多行字符串 |
table(數(shù)組形式) |
|
status(狀態(tài)回復(fù)) |
table(只有一個(gè)ok字段的數(shù)組) |
|
error(錯(cuò)誤回復(fù)) |
table(只有一個(gè)err字段的數(shù)組) |
Lua類(lèi)型到Redis類(lèi)型轉(zhuǎn)換關(guān)系如下:
|
Lua數(shù)據(jù)類(lèi)型 |
Redis返回?cái)?shù)據(jù)類(lèi)型 |
|
number(數(shù)字類(lèi)型) |
integer(整數(shù)回復(fù)) |
|
string(字符串類(lèi)型) |
bulk replay(字符串) |
|
table(數(shù)組形式) |
多行字符串 |
|
table(只有一個(gè)ok字段的數(shù)組) |
status(狀態(tài)回復(fù)) |
|
table(只有一個(gè)err字段的數(shù)組) |
error(錯(cuò)誤回復(fù)) |

我們?cè)谖⑿派?4小時(shí)期待你的聲音
解答本文疑問(wèn)/技術(shù)咨詢(xún)/運(yùn)營(yíng)咨詢(xún)/技術(shù)建議/互聯(lián)網(wǎng)交流