Redis如何回收過期資料?
大家讲道理
大家讲道理 2017-04-21 11:15:38
0
2
726

服務器經常會用到redis作為緩存,有很多數據都是臨時set以下,可能用過之後很久都不會再用到了(比如暫存session)那麼就有幾個問題了

  1. redis會自己回收清理不用的數據嗎?
  2. 如果能,如何配置?
  3. 如果不能,如何防止數據累加後大量占用存儲空間的問題?
大家讲道理
大家讲道理

光阴似箭催人老,日月如移越少年。

全部回覆(2)
小葫芦

redis預設把所有資料都永久儲存在記憶體中,當你需要持久化資料(儲存到磁碟)或自動刪除過期鍵,需要使用額外的指令或設定來完成; 如果你需要使用redis來完成你的業務需求(譬如cache),那麼你就必須遵循redis的設計規則;

至於你後面提到這個問題:即便我很有潔癖的每一條都加上了expire,你能保證多人開發中其他人也加上了expire?如果有人沒有呢,那數據就一直保存著

我是這樣想的:通常業務邏輯都會封裝成API接口,譬如登陸場景存session接口可能就是:void addLoginSession(string data, int timeout),然後別人在調用的時候其實壓根不管這裡面用的是redis還是memcache,所有的細節都必須只由API設計者消化;

順便說一下,redis如何清理資料庫中過期的鍵?它分為兩種:

  1. 惰性刪除:當你去操作一個鍵(譬如get name),redis首先會檢查這個鍵是否關聯了一個超時時間,如果有,則檢查是否超時,若超時則返回空,否則返回相應的值;
  2. 定時刪除:redis中有個時間事件,它會清理資料庫中已經過期的鍵(redis會限定該操作佔用的時間,避免阻塞客戶端的請求)
Peter_Zhu

可以用 expire 指令來設定過期時間。還有另外幾個指令也可以用來設定過期時間的,具體請查閱文件。

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板