在實際開發過程中經常會遇到一些有時效性資料,比如限時優惠活動,快取或者驗證碼之類的。過了一段時間就需要刪除這些資料。在關係型資料庫中一般都要增加乙個字段記錄資料的到期時間,然後周期性地檢查過期資料然後刪除。redis本身就對鍵過期提供了很好的支援。
在redis中可以使用expire命令設定乙個鍵的存活時間(ttl: time to live),過了這段時間,該鍵就會自動被刪除,expire命令的使用方法如下:
1
expire key ttl(單位秒)
命令返回1表示設定ttl成功,返回0表示鍵不存在或者設定失敗。
舉個例子:
1234567
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
返回值是鍵的剩餘時間,單位秒。
比如:
1234567
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,比如
12345
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.
例如:
1234567
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到期後不去主動檢測,而...