一、redis的key有六种过期策略
1、noeviction:一旦内存满则返回错误
2、allkeys-lru:对所有的key进行LRU
3、volatile-lru:只对设置了过期的key进行LRU(默认的方式)
4、allkeys-random:随机剔除一个key
5、volatile-random:对设置过期的key进行随机剔除一个
6、volatile-ttl:删除即将过期的key
根据官网的描述,redis使用的LRU并非真正的LRU算法,精确度并不高。redis3.0版本的LRU会维持一个候选池,性能会更加好。
二、一些内存和过期策略的设置和查看
1、设置实例的内存大小(本地执行可以不用-h $host,单位是B)
redis-cli -h $host -p $port config set maxmemory 1024
2、获取实例的内存大小
redis-cli -h $host -p $port config get maxmemory
3、设置过期策略
redis-cli -h $host -p $port config set maxmemory-policy volatile-lru
4、查看过期策略
redis-cli -h $host -p $port config get maxmemory-policy
说明:测试过volatile-lru,确实在满了之后如果有设置了过期时间的key就会执行LRU,可以继续插入。如果没有设置了过期时间的key了就会报错
时间: 2024-12-29 10:01:51