DECRBY
命令在 Redis 中是原子性的,這意味著在執(zhí)行過程中不會(huì)被其他命令中斷
然而,如果你需要確保在多個(gè)客戶端之間對(duì)同一個(gè)鍵執(zhí)行 DECRBY
操作的原子性,你可以使用以下方法:
DECRBY
操作,并將腳本發(fā)送給 Redis 服務(wù)器執(zhí)行。這樣可以確保在執(zhí)行過程中不會(huì)被其他命令中斷。這是一個(gè)示例 Lua 腳本:local key = KEYS[1]
local decrement = tonumber(ARGV[1])
local current_value = tonumber(redis.call("GET", key) or "0")
local new_value = current_value - decrement
if new_value < 0 then
return -1
else
redis.call("SET", key, new_value)
return new_value
end
要使用此腳本,你可以使用 EVAL
命令將其發(fā)送給 Redis 服務(wù)器:
EVAL <script> 1 your_key decrement_value
MULTI
、EXEC
、WATCH
等命令來實(shí)現(xiàn)。要使用事務(wù)確保 DECRBY
操作的原子性,你可以這樣做:MULTI
DECRBY your_key decrement_value
EXEC
如果事務(wù)中的任何命令失敗,整個(gè)事務(wù)將回滾,DECRBY
操作將不會(huì)執(zhí)行。