搜尋

首頁  >  問答  >  主體

Redis如何回收過期資料?

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

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

全部回覆(2)我來回復

  • 高洛峰

    高洛峰2017-04-21 11:17:38

    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會限定該操作佔用的時間,避免阻塞客戶端的請求)

    回覆
    0
  • 天蓬老师

    天蓬老师2017-04-21 11:17:38

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

    回覆
    0
  • 取消回覆