下面由Redis教程欄目給大家介紹redis數(shù)據(jù)淘汰策略,希望對需要的朋友有所幫助!
1、淘汰簡介
Redis官方給的警告,當(dāng)內(nèi)存不足時,Redis會根據(jù)配置的緩存策略淘汰部分keys,以保證寫入成功。當(dāng)無淘汰策略時或沒有找到適合淘汰的key時,Redis直接返回out of memory錯誤。
2、最大緩存配置
在redis中,允許用戶設(shè)置的最大使用內(nèi)存大小是 512G。
在 redis 中,允許用戶設(shè)置最大使用內(nèi)存大小 server.maxmemory,在內(nèi)存限定的情況下是很有用的。譬如,在一臺 8G 機子上部署了 4 個 redis 服務(wù)點,每一個服務(wù)點分配 1.5G 的內(nèi)存大小,減少內(nèi)存緊張的情況,由此獲取更為穩(wěn)健的服務(wù)。
3、6種數(shù)據(jù)淘汰策略
1、volatile-lru:從已設(shè)置過期時間的數(shù)據(jù)集(server.db[i].expires)中挑選最近最少使用的數(shù)據(jù)淘汰
2、volatile-ttl:從已設(shè)置過期時間的數(shù)據(jù)集(server.db[i].expires)中挑選將要過期的數(shù)據(jù)淘汰
3、volatile-random:從已設(shè)置過期時間的數(shù)據(jù)集(server.db[i].expires)中任意選擇數(shù)據(jù)淘汰
4、allkeys-lru:從數(shù)據(jù)集(server.db[i].dict)中挑選最近最少使用的數(shù)據(jù)淘汰
5、allkeys-random:從數(shù)據(jù)集(server.db[i].dict)中任意選擇數(shù)據(jù)淘汰
6、no-enviction(驅(qū)逐):禁止驅(qū)逐數(shù)據(jù)
4、建議
了解了Redis的淘汰策略之后,在平時使用時應(yīng)盡量主動設(shè)置/更新key的expire時間,主動剔除不活躍的舊數(shù)據(jù),有助于提升查詢性能。
Redis過期數(shù)據(jù)淘汰是指將鍵值對都刪除掉,請了解!!!!!!!!!!!!!