Keys的到期時間
通常Redis keys建立時沒有設定相關到期時間。他們會一直存在,除非使用顯示的命令移除,例如,使用DEL命令。
EXPIRE一類命令能關聯到一個有額外記憶體開銷的key。當key執行到期操作時,Redis會確保按照規定時間刪除他們。
key的到期時間和永久有效性可以通過EXPIRE和PERSIST命令(或者其他相關命令)來進行更新或者刪除到期時間。 到期精度
在 Redis 2.4 及以前版本,到期期時間可能不是十分準確,有0-1秒的誤差。
從 Redis 2.6 起,到期時間誤差縮小到0-1毫秒。 到期和持久
Keys的到期時間使用Unix時間戳記儲存(從Redis 2.6開始以毫秒為單位)。這意味著即使Redis執行個體不可用,時間也是一直在流逝的。
要想到期的工作處理好,電腦必須採用穩定的時間。 如果你將RDB檔案在兩台時鐘不同步的電腦間同步,有趣的事會發生(所有的 keys裝載時就會到期)。
即使正在啟動並執行執行個體也會檢查電腦的時鐘,例如如果你設定了一個key的有效期間是1000秒,然後設定你的電腦時間為未來2000秒,這時key會立即失效,而不是等1000秒之後。 Redis如何淘汰到期的keys
Redis keys到期有兩種方式:被動和主動方式。
當一些用戶端嘗試訪問它時,key會被發現並主動的到期。
當然,這樣是不夠的,因為有些到期的keys,永遠不會訪問他們。 無論如何,這些keys應該到期,所以定時隨機測試設定keys的到期時間。所有這些到期的keys將會從密鑰空間刪除。
具體就是Redis每秒10次做的事情:
測試隨機的20個keys進行相關到期檢測。
刪除所有已經到期的keys。
如果有多於25%的keys到期,重複步奏1.
這是一個平凡的機率演算法,基本上的假設是,我們的樣本是這個密鑰控制項,並且我們不斷重複到期檢測,直到到期的keys的百分百低於25%,這意味著,在任何給定的時刻,最多會清除1/4的到期keys。 在複製AOF檔案時如何處理到期
為了獲得正確的行為而不犧牲一致性,當一個key到期,DEL將會隨著AOF文字一起合成到所有附加的slaves。在master執行個體中,這種方法是集中的,並且不存在一致性錯誤的機會。
然而,當slaves串連到master時,不會獨立到期keys(會等到master執行DEL命令),他們任然會在資料集裡面存在,所以當slave當選為master時淘汰keys會獨立執行,然後成為master。