Redis中怎么利用Lua腳本實(shí)現(xiàn)一個(gè)分布式鎖

這期內(nèi)容當(dāng)中小編將會(huì)給大家?guī)?lái)有關(guān)redis中怎么利用Lua腳本實(shí)現(xiàn)一個(gè)分布式鎖,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

在融安等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站 網(wǎng)站設(shè)計(jì)制作定制開發(fā),公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),全網(wǎng)營(yíng)銷推廣,外貿(mào)營(yíng)銷網(wǎng)站建設(shè),融安網(wǎng)站建設(shè)費(fèi)用合理。

獲取鎖,可指定過(guò)期時(shí)間

--[[
	eval "if redis.call('setnx', KEYS[1], ARGV[1]) == 1 then redis.call('pexpire', KEYS[1], ARGV[2]); return 1; else return 0; end" 1 "myLock" 1 30000
	redis-cli -p 6379 -a password --eval ./tryLock.lua myLock , 1 30000
--]]
local function tryLock(key, val, expire)
	if(redis.call('setnx', key, val) == 1)
	then
		redis.call('pexpire', key, expire)
		return 1
	else
		return 0
	end
end

local key = KEYS[1]
local val = ARGV[1]
local expire = ARGV[2]
return tryLock(key, val, expire)

釋放鎖

--[[
	eval "if redis.call('get', KEYS[1]) == ARGV[1] then redis.call('del', KEYS[1]); return 1; else return 0; end" 1 myLock 1
	redis-cli -p 6379 -a password --eval ./releaseLock.lua myLock , 1
--]]
local function releaseLock(key, val)
	if(redis.call('get', key) == val)
	then
		if(redis.call('del', key) > 0)
		then
			return 1
		end
	end
	return 0
end
local key = KEYS[1]
local val = ARGV[1]
return releaseLock(key, val)

上述就是小編為大家分享的Redis中怎么利用Lua腳本實(shí)現(xiàn)一個(gè)分布式鎖了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

當(dāng)前標(biāo)題:Redis中怎么利用Lua腳本實(shí)現(xiàn)一個(gè)分布式鎖
網(wǎng)頁(yè)網(wǎng)址:http://muchs.cn/article4/gpppie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作、用戶體驗(yàn)、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站制作、App開發(fā)、網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)