概述
在實際開發過程中經常會遇到一些有時效性資料,比如限時優惠活動,緩衝或者驗證碼之類的。過了一段時間就需要刪除這些資料。在關係型資料庫中一般都要增加一個欄位記錄資料的到期時間,然後周期性地檢查到期資料然後刪除。Redis本身就對鍵到期提供了很好的支援。 Redis到期機制
在Redis中可以使用EXPIRE命令設定一個鍵的存活時間(ttl: time to live),過了這段時間,該鍵就會自動被刪除,EXPIRE命令的使用方法如下:
命令返回1表示設定ttl成功,返回0表示鍵不存在或者設定失敗。
舉個例子:
1234567891011 |
127.0.0.1:6379> set session 100OK127.0.0.1:6379> EXPIRE session 5(integer) 1127.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命令查看,使用方法如下:
傳回值是鍵的剩餘時間,單位秒。
比如:
1234567891011121314151617 |
127.0.0.1:6379> set session 100OK127.0.0.1:6379> EXPIRE session 10(integer) 1127.0.0.1:6379> TTL session(integer) 7127.0.0.1:6379> TTL session(integer) 5127.0.0.1:6379> TTL session(integer) 2127.0.0.1:6379> TTL session(integer) 0127.0.0.1:6379> TTL session(integer) -2127.0.0.1:6379> TTL session(integer) -2127.0.0.1:6379> |
可見,TTL的傳回值會隨著時間的流逝慢慢減少,10s之後鍵會被刪除,鍵不存在時TTL會返回-2,當沒有為鍵設定到期時間時,使用TTL擷取鍵的剩餘時間將會返回-1,比如
12345 |
127.0.0.1:6379> set url http://qifuguang.meOK127.0.0.1:6379> ttl url(integer) -1127.0.0.1:6379> |
如果想取消某個鍵的到期時間,可以使用PERSIST命令,用法如下:
清除成功返回1,失敗返回0.
例如:
1234567891011 |
127.0.0.1:6379> set title winwill2012OK127.0.0.1:6379> EXPIRE title 100(integer) 1127.0.0.1:6379> ttl title(integer) 97127.0.0.1:6379> PERSIST title(integer) 1127.0.0.1:6379> ttl title(integer) -1127.0.0.1:6379> |
除了PERSIST命令會清除鍵的到期時間之外,SET,GETSET命令也能清除鍵的到期時間,但是只對鍵進行操作的命令(比如INCR,LPUSH等等)不會清除鍵的到期時間。
EXPIRE命令的單位是秒,如果想要更精確的到期時間,則可以使用PEXPIRE命令,該命令的單位是毫秒,相應地可以使用PTTL看剩餘時間。
如果WATCH命令監控了一個具有到期時間的鍵,如果監控期間這個鍵到期被自動刪除,WATCH並不認為該鍵被改變 Redis到期機制的用途
有了到期機制就能實現很多跟時間相關的功能了,比如訪問頻率限制,作為緩衝等等,具體細節就不展開了,有疑問的可以留言。 聲明
本文原創,轉載請註明出處,本文連結:http://qifuguang.me/2015/09/30/Redis到期機制介紹/