新聞中心
Redis是一個(gè)基于內(nèi)存的高效非關(guān)系型NoSQL數(shù)據(jù)庫(kù),具有高并發(fā),可擴(kuò)展,快速讀寫等優(yōu)點(diǎn),因此應(yīng)用較廣泛。Redis提供了KEY-value存儲(chǔ),當(dāng)value為字符串類型時(shí),可以設(shè)置key的過(guò)期時(shí)間,以實(shí)現(xiàn)緩存過(guò)期自動(dòng)清理。但是,當(dāng)多個(gè)key同時(shí)過(guò)期時(shí),是如何觸發(fā)各個(gè)key的過(guò)期事件的呢?

Redis過(guò)期Key觸發(fā)機(jī)制主要是基于定時(shí)任務(wù)來(lái)實(shí)現(xiàn)的。Redis會(huì)定期檢查key是否過(guò)期,并執(zhí)行相應(yīng)的動(dòng)作。具體來(lái)說(shuō),Redis在啟動(dòng)的時(shí)候會(huì)開(kāi)啟定時(shí)任務(wù),每隔指定的時(shí)間(缺省默認(rèn)毫秒)檢查數(shù)據(jù)庫(kù)中的所有key過(guò)期時(shí)間,在key過(guò)期時(shí)執(zhí)行過(guò)期回調(diào)函數(shù),其中過(guò)期回調(diào)函數(shù)會(huì)執(zhí)行以下內(nèi)容:
1.根據(jù)定時(shí)任務(wù)結(jié)束時(shí)被檢查的鍵數(shù)量,調(diào)整首個(gè)被檢查的鍵的過(guò)期時(shí)間,這樣可以盡可能的縮短兩次觸發(fā)的時(shí)間間隔;
2.檢查鍵的過(guò)期時(shí)間是否超過(guò)當(dāng)前定時(shí)任務(wù)的時(shí)間間隔,如果已過(guò)期,則調(diào)用“expiredKey()”函數(shù);
3.刪除當(dāng)前檢查的key,并執(zhí)行回調(diào)函數(shù)的處理邏輯;
4.根據(jù)“expiredKey()”函數(shù)的返回值,確定是否需要繼續(xù)檢查其他過(guò)期鍵,如果有,則繼續(xù)觸發(fā)回調(diào)函數(shù);
5.如果有過(guò)期鍵,則重復(fù) 2-4 步,直到結(jié)束定時(shí)任務(wù)。
代碼示例:
/**
* key過(guò)期回調(diào)函數(shù)
*/
void expiredKey(char *key){
//處理過(guò)期回調(diào)邏輯
//刪除過(guò)期key
deleteKey(key);
//做計(jì)數(shù),是否還有要處理的key
haveKey--;
//返回是否需要繼續(xù)檢查
return haveKey;
}
/**
* 定時(shí)任務(wù)
*/
static void timerTask(void){
//首先調(diào)整首個(gè)被檢查的鍵的過(guò)期時(shí)間
check.cur_index = adjustExpiredTime();
//遍歷檢查過(guò)期key
for (i = check.cur_index; i
if (isExpired(key[i])){
//如果有過(guò)期key,則調(diào)用回調(diào)函數(shù)
if(expiredKey(key[i]) == true){
//如果iconKey返回true,則已沒(méi)有要檢查的key,跳出循環(huán)
break;
}
}
}
}
以上是Redis中過(guò)期Key觸發(fā)機(jī)制的實(shí)現(xiàn)原理,它能高效的處理多個(gè)key的定時(shí)觸發(fā)操作,能有效的降低Redis的內(nèi)存使用,提高Redis的使用效率。
香港服務(wù)器選創(chuàng)新互聯(lián),2H2G首月10元開(kāi)通。
創(chuàng)新互聯(lián)(www.cdcxhl.com)互聯(lián)網(wǎng)服務(wù)提供商,擁有超過(guò)10年的服務(wù)器租用、服務(wù)器托管、云服務(wù)器、虛擬主機(jī)、網(wǎng)站系統(tǒng)開(kāi)發(fā)經(jīng)驗(yàn)。專業(yè)提供云主機(jī)、虛擬主機(jī)、域名注冊(cè)、VPS主機(jī)、云服務(wù)器、香港云服務(wù)器、免備案服務(wù)器等。
當(dāng)前標(biāo)題:Redis中過(guò)期key觸發(fā)機(jī)制研究(redis過(guò)期觸發(fā))
新聞來(lái)源:http://www.5511xx.com/article/cdpdpes.html


咨詢
建站咨詢
