首頁 >資料庫 >Redis >redis鍵過期設定

redis鍵過期設定

尚
轉載
2020-05-21 09:10:374200瀏覽

redis鍵過期設定

EXPIRE key seconds

用來對一個鍵設定一個過期時間,第二個參數表示經過多少秒後鍵過期。一個鍵過期後, 這個鍵將會自動刪除。在Redis術語中,帶有過期時間的鍵經常被稱為volatile(易變的)。

當對這個鍵使用刪除,或是覆寫操作的時候, 過期時間會被清理,這些操作包括DEL, SET,GETSET和所有的*STORE指令。而那些修改鍵值的指令不會修改過期時間,例如修改數值的IINCR,為佇列中增加新值的LPUSH,修改hash表中的成員的HSET。

如果你只是想清除過期時間,可以呼叫PERSIST指令,這樣這個鍵就不會過期。過期時間是鍵的一個屬性,不會因為鍵修改名字(RENAME)而改變。當使用RENAME覆蓋了其他按鍵時, 只是過了一個覆蓋效果,改名的按鍵還會保留其過期時間。

注意一點:對一個鍵使用非正數呼叫EXPIRE/PEXPIRE指令,或使用一個過去時間呼叫EXPIREAT/PEXPIREAT會將這個鍵直接移除。

更新過期時間

對一個有過期時間的鍵呼叫EXPIRE可以更新這個鍵的過期時間。

傳回值

呼叫EXPIRE key seconds會回傳0或1,0表示鍵不存在,1表示鍵已經被設定逾時。

Redis如何處理帶有過期時間的鍵

帶有過期時間的鍵

正常情況下,redis的鍵是一直存在的,直到這個鍵被顯示刪除(透過DEL指令),或因為記憶體限制因素被清除。對某個鍵設定超時時間,需要額外的記憶體來記錄相關訊息,redis會保證,當鍵過期時,這個鍵會被移除。

過期時間精度

從redis2.6開始,過期時間的偏差在0到1毫秒之間。

過期時間邏輯

鍵的過期時間使用的是Unix的絕對時間戳(以毫秒作為精度),就算redis實例被關閉,到那個unix時間戳,鍵也會過期(只是不會立刻清理)。

如果你希望透過移動RDB檔案將一個redis中的資料移到另外一台電腦上的redis中,你需要確保這兩台電腦的unix絕對時間戳一致。

如果你對鍵設定了過期時間,那麼不要隨便修改你的電腦時間,因為redis會經常檢查系統時間,如果你將時間向前調整,會出現應該過期的鍵不過期。如果你將時間向後調整,會出現不該過期的鍵過期了。

redis如何清理過期的鍵:

redis透過兩種方式清理過期的鍵:被動清理和主動清理。

(1)被動清理:存取一個有過期時間的鍵時,如果發現這個鍵已經過期了,那麼就會將這個鍵清除。

(2)redis每秒會進行10次檢查,每次檢查包括:

  • 從帶有過期時間的鍵中隨機選擇20個,然後刪除所有過期的鍵。

  • 如果這20個中有超過25%的鍵已過期,那麼再次執行步驟1)。

這是一個簡單的機率演算法,我們假設選擇的鍵可以作為所有帶有過期時間的鍵的一個樣本。透過上述操作,我們可以基本確定超時的鍵所佔帶有超時時間的鍵的比率小於25%. 那麼因為未清理的過期的鍵,而多佔的內存也應該小於25%.

副本(replication)和AOF檔案中如何處理過期清理

為了不破壞一致性,當一個鍵過期清理時,DEL操作將會和AOF檔案以及所有的副本節點同步。透過這種方式,過期清理操作,由主節點負責,從節點不會處理鍵的過期清理,只會等待主節點的DEL指令,這樣主節點和從節點的鍵空間會保持一致。

更多redis知識請關注redis入門教學欄位。

以上是redis鍵過期設定的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:cnblogs.com。如有侵權,請聯絡admin@php.cn刪除