redis中的資料特徵
redis是一種記憶體級資料庫,所有資料均存放在記憶體中,記憶體中的資料可以通過ttl指令獲取其狀態
資料刪除策略
定時刪除
惰性刪除
定期刪除
資料刪除策略
資料刪除策略的目標
在記憶體占用與cpu占用之間尋找一種平衡,顧此失彼都會造成整體redis效能的下降,甚至引發伺服器宕機或記憶體洩露
定時刪除
優點:節約記憶體,到時就刪除,快速釋放掉不必要的記憶體占用
缺點:cpu壓力很大,無論cpu此時負載量多高,均占用cpu,會影響redis伺服器響應時間和指令吞吐量
總結:用處理器效能換取儲存空間 (拿時間換空間)
惰性刪除
優點:節約cpu效能,發現必須刪除的時候才刪除 缺點:記憶體壓力很大,出現長期占用記憶體的資料
總結:用儲存空間換取處理器效能(拿時間換空間)
定期刪除
當新資料進入redis時,如果記憶體不足怎麼辦?
影響資料逐出的相關配置
最大可使用記憶體
maxmemory
占用物理記憶體的比例,預設值為0,表示不限制。生產環境中根據需求設定,通常設定在50%以上。
每次選取待刪除資料的個數
maxmemory-samples
選取資料時並不會全庫掃瞄,導致嚴重的效能消耗,降低讀寫效能。因此採用隨機獲取資料的方式作為待檢測刪除資料
刪除策略
maxmemory-policy
達到最大記憶體後的,對被挑選出來的資料進行刪除的策略
資料逐出策略配置依據
使用info命令輸出監控資訊,查詢快取 hit 和 miss 的次數,根據業務需求調優redis配置
Redis刪除策略
目錄 1.過期資料 2.資料刪除策略 2.1 定時刪除 2.2 惰性刪除 2.3 定期刪除 2.4 三種資料刪除策略對比 3.逐出演算法 redis是一種記憶體級資料庫,所有資料均存放在記憶體中,記憶體中的資料可以通過ttl指令獲取其狀態 對於過期資料,redis內部是否真正釋放了其記憶體空間?目標...
Redis刪除策略
redis是一種記憶體級資料庫,所有資料均存放在記憶體中,記憶體中的資料可以通過ttl指令獲取其狀態 時效性資料的儲存結構 刪除策略是對expires的維護。定時刪除當前時間和expires中對過期時間一致時,定時器觸發刪除。優點 節省記憶體,到時間就刪除,快速釋放不必要的記憶體占用。缺點 cpu壓...
Redis刪除策略
redis中有個設定時間過期的功能,即對儲存在redis資料庫中的值可以設定乙個過期時間。作為乙個快取資料庫,這是非常實用的。如我們一般專案中的token或者一些登入資訊,尤其是簡訊驗證碼都是有時間限制的,按照傳統的資料庫處理方式,一般都是自己判斷過期,這樣無疑會嚴重影響專案效能 set key的時...