redis如何設(shè)置key的有效期
redis設(shè)置key的有效期
Key命令
設(shè)置key的過(guò)期時(shí)間。
查詢(xún)當(dāng)前所有的key
expire key second
:設(shè)置key的過(guò)期時(shí)間
若執(zhí)行ttl key 顯示為-2 則說(shuō)明改值不存在緩存中
顯示為-1則是持久化的 (不會(huì)失效)
若將其設(shè)置了失效時(shí)間 那么就會(huì)顯示剩余的失效時(shí)間
徹底理解redis有效期問(wèn)題
EXPIRE key seconds
起始版本:1.0.0
時(shí)間復(fù)雜度:O(1)
返回值:1 如果成功設(shè)置過(guò)期時(shí)間;0 如果key不存在或者不能設(shè)置過(guò)期時(shí)間。
為給定 key設(shè)置生存時(shí)間,當(dāng) key過(guò)期時(shí)(生存時(shí)間為 0),它會(huì)被自動(dòng)刪除。
1.過(guò)期時(shí)間跟著key走,與值無(wú)關(guān)
在Redis中,帶有過(guò)期時(shí)間的key被稱(chēng)為『易失的』(volatile)。 過(guò)期時(shí)間可以通過(guò)使用 DEL命令來(lái)刪除整個(gè)key來(lái)移除,或者被 SET和 GETSET命令覆寫(xiě)(overwrite),這意味著,如果一個(gè)命令只是修改(alter)一個(gè)帶過(guò)期時(shí)間的 key的值而不是用一個(gè)新的 key值來(lái)代替(replace)它的話,那么過(guò)期時(shí)間不會(huì)被改變。比如說(shuō),對(duì)一個(gè) key執(zhí)行 INCR命令,對(duì)一個(gè)列表進(jìn)行 LPUSH命令,或者對(duì)一個(gè)哈希表執(zhí)行 HSET命令,這類(lèi)操作都不會(huì)修改 key本身的過(guò)期時(shí)間。
2.設(shè)置永久有效期
使用PERSIST命令可以清除超時(shí),使其變成一個(gè)永久的key。
3.rename命令對(duì)有效期影響
如果key被RENAME命令修改,相關(guān)的超時(shí)時(shí)間會(huì)轉(zhuǎn)移到新key上面。
如果key被RENAME命令修改,比如原來(lái)就存在Key_A,然后調(diào)用RENAME Key_B Key_A命令,這時(shí)不管原來(lái)Key_A是永久的還是設(shè)置為超時(shí)的,都會(huì)由Key_B的有效期狀態(tài)覆蓋。
4.刷新過(guò)期時(shí)間
對(duì)已經(jīng)有過(guò)期時(shí)間的key執(zhí)行EXPIRE操作,將會(huì)更新它的過(guò)期時(shí)間。
5.過(guò)期精度
在 Redis 2.4 及以前版本,過(guò)期期時(shí)間可能不是十分準(zhǔn)確,有0-1秒的誤差。
從 Redis 2.6 起,過(guò)期時(shí)間誤差縮小到0-1毫秒。
6.外界因素對(duì)過(guò)期時(shí)間影響
Keys的過(guò)期時(shí)間使用Unix時(shí)間戳存儲(chǔ)(從Redis 2.6開(kāi)始以毫秒為單位)。這意味著即使Redis實(shí)例不可用,時(shí)間也是一直在流逝的。
要想過(guò)期的工作處理好,計(jì)算機(jī)必須采用穩(wěn)定的時(shí)間。 如果你將RDB文件在兩臺(tái)時(shí)鐘不同步的電腦間同步,有趣的事會(huì)發(fā)生(所有的 keys裝載時(shí)就會(huì)過(guò)期)。
即使正在運(yùn)行的實(shí)例也會(huì)檢查計(jì)算機(jī)的時(shí)鐘,例如如果你設(shè)置了一個(gè)key的有效期是1000秒,然后設(shè)置你的計(jì)算機(jī)時(shí)間為未來(lái)2000秒,這時(shí)key會(huì)立即失效,而不是等1000秒之后。
7.Redis如何淘汰過(guò)期的keys
Redis keys過(guò)期有兩種方式:被動(dòng)和主動(dòng)方式。
當(dāng)一些客戶(hù)端嘗試訪問(wèn)它時(shí),key會(huì)被發(fā)現(xiàn)并主動(dòng)的過(guò)期。
當(dāng)然,這樣是不夠的,因?yàn)橛行┻^(guò)期的keys,永遠(yuǎn)不會(huì)訪問(wèn)他們。無(wú)論如何,這些keys應(yīng)該過(guò)期,所以定時(shí)隨機(jī)測(cè)試設(shè)置keys的過(guò)期時(shí)間。所有這些過(guò)期的keys將會(huì)刪除。
具體就是Redis每秒10次做的事情:
1).測(cè)試隨機(jī)的20個(gè)keys進(jìn)行相關(guān)過(guò)期檢測(cè)。
2).刪除所有已經(jīng)過(guò)期的keys。
3).如果有多于25%的keys過(guò)期,重復(fù)步奏1.
這是一個(gè)平凡的概率算法,基本上的假設(shè)是,我們的樣本是這個(gè)密鑰控件,并且我們不斷重復(fù)過(guò)期檢測(cè),直到過(guò)期的keys的百分比低于25%,這意味著,在任何給定的時(shí)刻,最多會(huì)清除1/4的過(guò)期keys。
8.在復(fù)制AOF文件時(shí)如何處理過(guò)期
為了獲得正確的行為而不犧牲一致性,當(dāng)一個(gè)key過(guò)期,DEL將會(huì)隨著AOF文字一起合成到所有附加的slaves。在master實(shí)例中,這種方法是集中的,并且不存在一致性錯(cuò)誤的機(jī)會(huì)。
然而,當(dāng)slaves連接到master時(shí),不會(huì)獨(dú)立過(guò)期keys(會(huì)等到master執(zhí)行DEL命令),他們?nèi)稳粫?huì)在數(shù)據(jù)集里面存在,所以當(dāng)slave當(dāng)選為master時(shí)淘汰keys會(huì)獨(dú)立執(zhí)行,然后成為master。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Redis數(shù)據(jù)結(jié)構(gòu)之跳躍表使用學(xué)習(xí)
這篇文章主要為大家介紹了Redis數(shù)據(jù)結(jié)構(gòu)之跳躍表使用學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07淺析PHP分布式中Redis實(shí)現(xiàn)Session的方法
這篇文章主要介紹了PHP分布式中Redis實(shí)現(xiàn)Session的方法,文中詳細(xì)介紹了兩種方法的使用方法,并給出了測(cè)試的示例代碼,有需要的朋友可以參考借鑒,下面來(lái)一起看看吧,2016-12-12Jedis操作Redis實(shí)現(xiàn)模擬驗(yàn)證碼發(fā)送功能
Redis是一個(gè)著名的key-value存儲(chǔ)系統(tǒng),也是nosql中的最常見(jiàn)的一種,這篇文章主要給大家介紹Jedis操作Redis實(shí)現(xiàn)模擬驗(yàn)證碼發(fā)送功能,感興趣的朋友一起看看吧2021-09-09如何使用Redis保存用戶(hù)會(huì)話Session詳解
這篇文章主要給大家介紹了關(guān)于如何使用Redis保存用戶(hù)會(huì)話Session的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01