为什么要由逐出算法
情景分析,如果有新数据进入redis,但是数据都没有过期,而且内存也不足,那么这时就需要逐出算法,来腾出一些空间
Redis使用内存存储数据,在执行每一个命令前,会调用freeMemoryIfNeeded()检测内存是否充足
注意:逐出数据的过程不是100%能够清理出足够的可使用的内存空间,如果不成功则反复执行,当对所有数据尝试完毕后,如果不能达到内存清理的要求,将出现错误信息
配置
#最大可使用内存,占用物理内存的比例,默认值为0,表示不限制,生产环境根据需求设定,通常设置在50%以上
maxmemory
#每次选取待删除数据的个数,选取数据时并不会全库扫描,导致严重的性能消耗,降低读写性能,因此采用随机获取数据的凡是作为待检测删除数据
maxmemory-samples
#删除策略,达到最大内存后,对被挑选出来的数据进行删除的策略
maxmemory-policy
逐出算法
- 检查易失数据(可能会过去的数据)
- volatile-lru:挑选最近最少使用的数据淘汰
- volatile-lfu:挑选最近使用次数最少的数据淘汰
- volatile-ttl:挑选将要过期的数据淘汰
- volatile-random:任意选择数据淘汰
- 检查全库数据
- allkeys-lru:挑选最近最少使用的数据淘汰
- allkeys-lfu:挑选最近使用次数最少的数据淘汰
- allkeys-random:任意选择数据淘汰
- 放弃数据驱逐
- no-enviction:禁止驱逐数据
以上在redis.conf文件中修改
maxmemory-policy volatile-lru