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

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


咨詢
建站咨詢
