判斷鎖的標(biāo)志和刪除鎖不是原子操作。
引入lua腳本
1.創(chuàng)建 lua文件放在resources目錄下
獲取k的值,比較k的值是否一致,若一致就刪除,不一致就返回0
local k = KEYS[1]
local v = ARGV[1]
-- 獲取k的值
local id = redis.call("get",k)
-- 比較k的值是否一致
if (v==id)
then
-- 若一致就刪除
return redis.call("del",k)
end
-- 不一致就返回0
return 0
2.springboot讀取配置文件用靜態(tài)代碼塊,只加載一次
private static final DefaultRedisScriptSECKILL_SCRIPT;
static {
SECKILL_SCRIPT = new DefaultRedisScript<>();
SECKILL_SCRIPT.setLocation(new ClassPathResource("test.lua")); //lua腳本路徑
SECKILL_SCRIPT.setResultType(Long.class); //返回值
}
3.執(zhí)行stringRedisTemplate.execute(
SECKILL_SCRIPT,
Collections.singletonList("a"), // K
"b" // V
);
你是否還在尋找穩(wěn)定的海外服務(wù)器提供商?創(chuàng)新互聯(lián)www.cdcxhl.cn海外機(jī)房具備T級(jí)流量清洗系統(tǒng)配攻擊溯源,準(zhǔn)確流量調(diào)度確保服務(wù)器高可用性,企業(yè)級(jí)服務(wù)器適合批量采購(gòu),新人活動(dòng)首月15元起,快前往官網(wǎng)查看詳情吧
網(wǎng)頁題目:springboot使用lua腳本解決分布式鎖釋放的問題-創(chuàng)新互聯(lián)
標(biāo)題URL:http://aaarwkj.com/article8/dspiop.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App開發(fā)、建站公司、網(wǎng)站制作、虛擬主機(jī)、軟件開發(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í)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容