• Redis系列之-—内存淘汰策略(笔记)


    一、Redis

    ---获取设置的Redis能使用的最大内存大小
    127.0.0.1:6379[10]> config get maxmemory
    1) "maxmemory"
    2) "0"
    
    --获取当前内存淘汰策略:
    127.0.0.1:6379[10]> config get maxmemory-policy
    1) "maxmemory-policy"
    2) "noeviction"

    注意,在64bit系统下,maxmemory设置为0表示不限制Redis内存使用,在32bit系统下,maxmemory不能超过3GB


    二、Redis的内存淘汰策略
    既然可以设置Redis最大占用内存大小,那么配置的内存就有用完的时候。那在内存用完的时候,还继续往Redis里面添加数据不就没内存可用了吗?

    实际上Redis定义了几种策略用来处理这种情况:
    noeviction(默认策略):对于写请求不再提供服务,直接返回错误(DEL请求和部分特殊请求除外)
    allkeys-lru:从所有key中使用LRU算法进行淘汰
    volatile-lru:从设置了过期时间的key中使用LRU算法进行淘汰
    allkeys-random:从所有key中随机淘汰数据
    volatile-random:从设置了过期时间的key中随机淘汰
    volatile-ttl:在设置了过期时间的key中,根据key的过期时间进行淘汰,越早过期的越优先被淘汰

    当使用volatile-lru、volatile-random、volatile-ttl这三种策略时,如果没有key可以被淘汰,则和noeviction一样返回错误

  • 相关阅读:
    Tornado web 框架
    mysql_orm模块操作数据库(17.6.29)
    mysql小结篇3 索引、分页、执行计划--(17.6.28)
    Oracle触发器Trigger2行级
    Oracle触发器Trigger基础1
    Oracle函数function
    Oracle异常的抛出处理
    Oracle利用过程procedure块实现银行转账
    Oracle存储过程procedure
    PL/SQL块loop..各种循环练习
  • 原文地址:https://www.cnblogs.com/liuyitan/p/12082657.html
Copyright © 2020-2023  润新知