首頁  >  文章  >  資料庫  >  redis有效期限在哪設置

redis有效期限在哪設置

(*-*)浩
(*-*)浩原創
2019-11-30 10:18:467250瀏覽

本文對redis的過期處理機製做個簡單的概述,讓大家有個基本的認識。

redis有效期限在哪設置

Redis中有個設定時間過期的功能,也就是儲存在redis資料庫中的值可以設定一個過期時間。作為一個快取資料庫,這是非常實用的。

如我們一般項目中的token或一些登錄信息,尤其是短信驗證碼都是有時間限制的,按照傳統的數據庫處理方式,一般都是自己判斷過期,這樣無疑會嚴重影響項目性能。 (推薦學習:Redis影片教學

一、有效時間設定:

redis對儲存值的過期處理實際上是針對該值的鍵(key)處理的,即時間的設定也是設定key的有效時間。 Expires字典保存了所有鍵的過期時間,Expires也被稱為過期欄位。

四種處理策略

EXPIRE 將key的生存時間設定為ttl秒

PEXPIRE 將key的產生時間設定為ttl毫秒

EXPIREAT 將key的過期時間設定為timestamp所代表的的秒數的時間戳記

PEXPIREAT 將key的過期時間設定為timestamp所代表的的毫秒數的時間戳

其實以上幾種處理方式都是根據PEXPIREAT來實現的,設定生存時間的時候是redis內部計算好時間之後在記憶體處理的,最終的處理都會轉向PEXPIREAT。

1、2兩種方式是設定一個過期的時間段,就是咱們處理驗證碼最常用的策略,設定三分鐘或五分鐘後失效,把分鐘數轉換成秒或毫秒儲存到redis中。

3、4兩種方式是指定一個過期的時間 ,例如優惠券的過期時間是某年某月某日,只是單位不一樣。

二、過期處理

過期鍵的處理就是把過期鍵刪除,這裡的操作主要是針對過期欄位處理的。

Redis中有三種處理策略:定時刪除、惰性刪除和定期刪除。

定時刪除:在設定鍵的過期時間的時候建立一個定時器,當過期時間到的時候立刻執行刪除操作。不過這種處理方式是即時的,不管這個時間內有多少過期鍵,不管伺服器現在的運作狀況,都會立刻執行,所以對CPU不是很友善。

惰性刪除:惰性刪除策略不會在鍵過期的時候立刻刪除,而是當外部指令取得這個鍵的時候才會主動刪除。處理過程為:接收get執行、判斷是否過期(這裡按過期判斷)、執行刪除操作、返回nil(空)。

定期刪除:定期刪除是設定時間間隔,每個時間段都會偵測是否有過期鍵,如果有執行刪除操作。這個概念應該要很好理解。

更多Redis相關技術文章,請造訪Redis入門教學欄位學習!

以上是redis有效期限在哪設置的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn