Redis過期數據和刪除策略

爲什麼要有過期數據

因爲內存有限,有些數據不需要一直在內存中,可以設定一些規則,將一些數據設置過期,在內存中刪除,當然也不是隨便刪除,也要考慮到CPU的繁忙與空閒,以免出現Redis各種命令執行很多,但是正好出現大量過期數據,已造成服務器宕機

刪除策略

目標

是在內存佔用與CPU佔用之間尋找一種平衡,顧此失彼都會造成redis性能下降,甚至引發服務器宕機或內存泄漏(CPU忙的時候,不要去打擾,閒的時候去打擾)

定時刪除

創建一個定時器,當key設置有過期實踐,且過期時間到達時,由定時器任務立即執行對鍵的刪除操作
優點:節約內存,到時就刪除,快速釋放掉不必要的內存佔用
缺點:CPU壓力很大,無論CPU此時負載量多高,均佔用CPU,會影響redis服務器相應時間和指令吞吐量
總結:用處理器性能換取存儲空間(時間換空間)

惰性刪除

數據到達過期時間,不做處理,等下次訪問該數據時進行處理,如未過期,返回數據,發現已過期,刪除,返回不存在
優點:節約CPU性能,發現必須刪除的時候才刪除
缺點:內存壓力很大,出現長期佔用內存的數據
總結:用存儲空間換取處理器性能(空間換時間)

定期刪除

週期性輪詢redis庫中的時效性數據,採用隨機抽取的策略,利用過期數據佔用的方式控制刪除頻度
在這裏插入圖片描述
特點:

  • CPU性能佔用設置有峯值,檢測頻度可自定義設置
  • 內存壓力不是很大,長期佔用內存的冷數據會被持續清理
    總結:週期性抽查存儲空間(隨機抽查,重點抽查)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章