Redis 缓存过期处理与内存淘汰机制

Redis 缓存过期处理与内存淘汰机制

设置了TTL过期策略的缓存

设置了expire的key缓存过期了,但是服务器的内存还是会被占用,这是因为redis所基于的两种删除策略

主动删除

定时随机的检查过期的key,如果过期则清理删除。(每秒检查次数在redis.conf中的hz配置)

被动删除

当客户端请求一个已经过期的key的时候,那么redis会检查这个key是否过期,如果过期了,则删除,然后返回一个nil。这种策略
友好,不会有太多的损耗,但是内存占用会比较高。

所以,虽然key过期了,但是只要没有被redis清理,那么其实内存还是会被占用着的。

内存沾满了怎么办?

这时候就需要内存淘汰机制了MEMORY MANAGEMENT

# volatile-lru -> Evict using approximated LRU among the keys with an expire set.
# allkeys-lru -> Evict any key using approximated LRU.
# volatile-lfu -> Evict using approximated LFU among the keys with an expire set.
# allkeys-lfu -> Evict any key using approximated LFU.
# volatile-random -> Remove a random key among the ones with an expire set.
# allkeys-random -> Remove a random key, any key.
# volatile-ttl -> Remove the key with the nearest expire time (minor TTL)
# noeviction -> Don't evict anything, just return an error on write operations.
#
# LRU means Least Recently Used
# LFU means Least Frequently Used

LFU就是用的最少的
LRU就是最近用的最少的
两种策略用的算法不一样


* noeviction:旧缓存永不过期,新缓存设置不了,返回错误 
* allkeys-lru:清除最少用的旧缓存,然后保存新的缓存(推荐使用) 
* allkeys-random:在所有的缓存中随机删除(不推荐) 
* allkeys-lfu:清除使用最少的缓存 
* volatile-lru:在那些设置了expire过期时间的缓存中,清除最少用的旧缓存,然后保存新的缓存 
* volatile-random:在那些设置了expire过期时间的缓存中,随机删除缓存 
* volatile-ttl:在那些设置了expire过期时间的缓存中,删除即将过期的
* volatile-lru:在那些设置了expire过期时间的缓存中,删除最近最少使用的
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值