Redis過期機制介紹

2021-07-06 07:09:04 字數 2892 閱讀 5698

在實際開發過程中經常會遇到一些有時效性資料,比如限時優惠活動,快取或者驗證碼之類的。過了一段時間就需要刪除這些資料。在關係型資料庫中一般都要增加乙個字段記錄資料的到期時間,然後周期性地檢查過期資料然後刪除。redis本身就對鍵過期提供了很好的支援。

在redis中可以使用expire命令設定乙個鍵的存活時間(ttl: time to live),過了這段時間,該鍵就會自動被刪除,expire命令的使用方法如下:

1

expire key ttl

(單位秒)

命令返回1表示設定ttl成功,返回0表示鍵不存在或者設定失敗。

舉個例子:

123

4567

891011

127.0

.0.1:6379> set session 100

ok127.0

.0.1:6379> expire session 5

(integer) 1

127.0

.0.1:6379> get session

"100"

127.0

.0.1:6379> get session

"100"

127.0

.0.1:6379> get session

(nil)

127.0.0.1:6379>

上例可見,先設定session的值為100,然後設定他的ttl為5s,之後連續幾次使用get命令獲取session,5s之後將獲取不到session,因為ttl時間已到,session被刪除。

如果想知道乙個鍵還有多長時間被刪除,則可以使用ttl命令檢視,使用方法如下:

1

ttl key

返回值是鍵的剩餘時間,單位秒。

比如:

123

4567

891011

1213

1415

1617

127.0

.0.1

:6379> set

session 100

ok127.0

.0.1

:6379> expire

session 10

(integer) 1

127.0

.0.1

:6379> ttl

session

(integer) 7

127.0

.0.1

:6379> ttl

session

(integer) 5

127.0

.0.1

:6379> ttl

session

(integer) 2

127.0

.0.1

:6379> ttl

session

(integer) 0

127.0

.0.1

:6379> ttl

session

(integer) -2

127.0

.0.1

:6379> ttl

session

(integer) -2

127.0

.0.1

:6379>

可見,ttl的返回值會隨著時間的流逝慢慢減少,10s之後鍵會被刪除,鍵不存在時ttl會返回-2,當沒有為鍵設定過期時間時,使用ttl獲取鍵的剩餘時間將會返回-1,比如

123

45

127.0

.0.1:6379> set url

ok127.0

.0.1:6379> ttl url

(integer) -1

127.0.0.1:6379>

如果想取消某個鍵的過期時間,可以使用persist命令,用法如下:

1

persist key

清除成功返回1,失敗返回0.

例如:

123

4567

891011

127.0

.0.1

:6379> set

title

winwill2012

ok127.0

.0.1

:6379> expire

title 100

(integer) 1

127.0

.0.1

:6379> ttl

title

(integer) 97

127.0

.0.1

:6379> persist

title

(integer) 1

127.0

.0.1

:6379> ttl

title

(integer) -1

127.0

.0.1

:6379>

除了persist命令會清除鍵的過期時間之外,set,getset命令也能清除鍵的過期時間,但是只對鍵進行操作的命令(比如incr,lpush等等)不會清除鍵的過期時間。

expire命令的單位是秒,如果想要更精確的過期時間,則可以使用pexpire命令,該命令的單位是毫秒,相應地可以使用pttl看剩餘時間。

如果watch命令監控了乙個具有過期時間的鍵,如果監控期間這個鍵過期被自動刪除,watch並不認為該鍵被改變

redis過期機制

在實際開發過程中經常會遇到一些有時效性資料,比如限時優惠活動,快取或者驗證碼之類的。過了一段時間就需要刪除這些資料。在關係型資料庫中一般都要增加乙個字段記錄資料的到期時間,然後周期性地檢查過期資料然後刪除。redis本身就對鍵過期提供了很好的支援。在redis中可以使用expire命令設定乙個鍵的存...

Redis過期機制

目錄ttl key 獲取key的過期剩餘時間,不存在返回 2 無過期時間返回 1 pttl key 同ttl,毫秒 expire key ttl 將鍵的生存時間設為 ttl 秒 pexpire key ttl 將鍵的生存時間設為 ttl 毫秒 expireat key timestamp 將鍵的過期...

Redis快取過期機制

redis可以通過設定乙個過期時間expire來處理快取,其中處理方式有兩種 主動 定期刪除,redis會抽查隨機的key,預設1秒十次,一旦抽查的key過期了,就會給刪除,配置的屬性在redis.conf中,hz等於10,表示1秒抽查10次 hz 10 被動 惰性刪除,key到期後不去主動檢測,而...