Redis研究总结

Redis删除策略

定期删除+惰性删除

定期:每100ms随机抽取一些设置了过期时间的key,检查是否过期,如果过期那就删除

惰性删除:当获取某个key时,redis检查一下这个key是否已过期,如果过期那就删除

内存不够时,走redis的内存淘汰机制:no eviction、allkeys-lru(对所有的key删除最近最少使用的key)、alleys-random(对所有的key随机删除)、volatile-lru(对设置了过期时间的key删除最近最少使用的key)、volatile-random(对设置了过期时间的key随机删除)、volatile-ttl(仅淘汰设置了过期时间的key,淘汰生存时间TTL最小的key)

 

一般的经验规则:

  • 使用allkeys-lru策略:当预期请求符合一个幂次分布(二八法则等),比如一部分的子集元素比其它其它元素被访问的更多时,可以选择这个策略。
  • 使用allkeys-random:循环连续的访问所有的键时,或者预期请求分布平均(所有元素被访问的概率都差不多)
  • 使用volatile-ttl:要采取这个策略,缓存对象的TTL值最好有差异

volatile-lru 和 volatile-random策略,当你想要使用单一的Redis实例来同时实现缓存淘汰和持久化一些经常使用的键集合时很有用。未设置过期时间的键进行持久化保存,设置了过期时间的键参与缓存淘汰。不过一般运行两个实例是解决这个问题的更好方法。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章