本文將介紹redis相關知識,主要內容是分析redis過期鍵未釋放原因,希望對需要的朋友有幫助!讓我們一起來看看吧!
背景:
1、redis 版本5.0;
2、32G 的redis 雲端伺服器,記憶體持續上漲,過期鍵佔用記憶體一直未釋放。記憶體使用如下圖:
近期 redis 操作:把 2,000 萬永不過期鍵,隨機分配 7-20 天的過期時間。
優化過程:
1、對阿里雲「離線全量key 分析」 持續觀察幾天;
2、發現過期鍵的內存一直沒有釋放,從2G 漲到5G;
3、分析過期鍵內存不釋放原因;
4、調整redis 的hz 參數,從10 調30,發現沒有變化;
5、分析redis 原始碼。
6、結論:redis 記憶體不釋放原因:近期把 2000 萬個鍵設定過期時間,導致垃圾回收命中率達不到 25%,不會重複輪換過期鍵。 (原始碼檔案:expire.c,activeExpireCycle 函數)。
hz 說明【推薦學習:redis影片教學】
7、最終處理方式:無需任何操作,隨著過期鍵增多命中率提高,記憶體最終會釋放(想加快把“hz” 參數設定越大越快,但是會消耗更多CPU 資源,可參數阿里雲文檔)。
以上是帶你仔細分析redis過期鍵未釋放原因!的詳細內容。更多資訊請關注PHP中文網其他相關文章!