1. 程式人生 > >redis鍵過期 (redis 2.6及以上)

redis鍵過期 (redis 2.6及以上)

發現 ash name 副本 文件 unix 刪除 所有 second

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次檢查,每次檢查包括:

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

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

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

副本(replication)和AOF文件中如何處理過期清理

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

redis鍵過期 (redis 2.6及以上)