Redis逐出算法

    技术2023-09-01  108

    目录

    为什么要由逐出算法配置逐出算法

    为什么要由逐出算法

    情景分析,如果有新数据进入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
    Processed: 0.008, SQL: 10