Redis到期時間

來源:互聯網
上載者:User
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。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.