redis的过期策略和内存淘汰机制

redis是否用到家,从这就能看出来,比如你redis只能存5G数据,可是你写了10G,那会删5G的数据,怎么删的,这个问题思考过吗?

正解:redis采用的是定时删除+惰性删除策略

1.为什么不使用定时删除策略

定时删除,用一个定时器来负责监视key,过期则自动删除,虽然内存及时释放,但是是否消耗cpu资源,在大并发请求下,cpu要将时间应用在处理请求,而不是用了删除key,因此没有采用这一策略。

2.定时删除+惰性删除如何工作

定时删除,redis默认没100ms检查,有过期key则定时删除。需要说明的是,redis不是每隔100ms将所有的key检查一次,而是随机抽取进行检查,如果采用定期删除策略,会导致很多key到时间没有删除,于是,惰性删除派上用场。

3、采用定是删除+惰性删除没其他问题了吗

不是的,如果定是删除没有删除的key。并且你也没有即时去请求key,也就是说惰性删除没生效,这样,redis的内存会越来越高,那么就应该采取内存淘汰机制。

在redis.conf中有一行

maxmemory-policy volatile-lru

该配置就是配置内存淘汰机制

noeviction:当内存不足容纳写入数据时,新写入操作会报错。

allkeys-lru:当内存不足容纳新写入数据时,在键空间中,移除最近最少使用的key(推荐使用,目前项目在使用这种)

allkeys-random:当内存不足以容纳新写入数据时,在键空间中,随机移除某个key(估计没人会用吧)

volatile-lru:当内存不足容纳新写入数据时,在设置了过期时间的键空间中,移除最近最少使用的keky,这种情况一般是把redis既当缓存,又做持久化存储的时候采用。(不推荐)

voliatile-ttl:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,有更早过期时间的key优先移除(不推荐)

 

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值