日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

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

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Redis鎖的艱難切換過程(redis鎖切換)

在分布式環(huán)境中,對資源的訪問往往需要排除來自并發(fā)的多個請求的競爭,使用Redis鎖加強了對資源的保護,將鎖的管理從應用本身中獨立出來,統(tǒng)一由Redis服務器來進行控 制。然而,在實際開發(fā)中,遇到Redis異常,往往需要切換到另一個Redis實例,Redis lock受到非常多的開發(fā)者關注,它極大的提高了應用的性能和安全性,但是,切換Redis Lock是一個比較艱難的過程。

成都服務器托管,成都創(chuàng)新互聯(lián)公司提供包括服務器租用、資陽主機托管、帶寬租用、云主機、機柜租用、主機租用托管、CDN網(wǎng)站加速、域名與空間等業(yè)務的一體化完整服務。電話咨詢:028-86922220

需要確定在切換Redis Lock時,舊的Lock是否還存在,否則新的Lock可能會和舊的Lock發(fā)生沖突,另一方面,同一個Lock可能在多個節(jié)點上被同時加鎖,如果不進行同步操作,將可能導致資源競爭。為避免舊Lock和新Lock發(fā)生沖突,可以給新Lock提供一個不與舊Lock同時存在的新值,如UUID;同時,針對已經(jīng)存在的鎖,可以在新Redis實例上同步設置這個Lock,以保證兩個實例之間的數(shù)據(jù)一致。

//獲取Redis鎖
public boolean getRedisLock(Jedis redis,string params) {
//共享鎖,設置過期時間
String result=redis.set(params,params, SET_IF_NOT_EXIST, SET_WITH_EXPIRE_TIME, SECONDS);
if(LOCK_SUCCESS.equals(result)) {
return true;
}
return false;
}
//釋放Redis鎖
public void releaseRedisLock(Jedis redis,String params) {
redis.del(params);
}
// 在切換時,需要先釋放舊的鎖
public void switchRedisLock(String oldParams, String newParams) {
// 釋放舊的Redis鎖
releaseRedisLock(oldParams);
//獲取新的Redis鎖
getRedisLock(newParams);
}

上面提供了實現(xiàn)Redis Lock的切換的過程,但是,實現(xiàn)該切換還存在一些其他的挑戰(zhàn)。首先是檢測舊的Lock在存活的時間,只有確認舊的Lock的時間沒有超過設定的過期時間,新的Lock才能正常工作;Redis集群環(huán)境中節(jié)點之間的數(shù)據(jù)同步也是必須要滿足的條件,否則將可能導致節(jié)點之間數(shù)據(jù)不一致,進而影響Redis Lock的使用。因此,實現(xiàn)Redis Lock的切換艱難而微妙,在進行實現(xiàn)的過程中,既需要考慮Redis數(shù)據(jù)的完整性和一致性,又需要考慮Lock的安全性。

香港服務器選創(chuàng)新互聯(lián),2H2G首月10元開通。
創(chuàng)新互聯(lián)(www.cdcxhl.com)互聯(lián)網(wǎng)服務提供商,擁有超過10年的服務器租用、服務器托管、云服務器、虛擬主機、網(wǎng)站系統(tǒng)開發(fā)經(jīng)驗。專業(yè)提供云主機、虛擬主機、域名注冊、VPS主機、云服務器、香港云服務器、免備案服務器等。


文章名稱:Redis鎖的艱難切換過程(redis鎖切換)
文章位置:http://www.5511xx.com/article/ccsgssg.html