博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
redis的过期策略以及内存淘汰机制
阅读量:7223 次
发布时间:2019-06-29

本文共 1116 字,大约阅读时间需要 3 分钟。

redis采用的是定期删除+惰性删除策略。

为什么不用定时删除策略?

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

定期删除+惰性删除是如何工作的呢?

定期删除,redis默认每个100ms检查,是否有过期的key,有过期key则删除。需要说明的是,redis不是每个100ms将所有的key检查一次,而是随机抽取进行检查(如果每隔100ms,全部key进行检查,redis岂不是卡死)。因此,如果只采用定期删除策略,会导致很多key到时间没有删除。

于是,惰性删除派上用场。也就是说在你获取某个key的时候,redis会检查一下,这个key如果设置了过期时间那么是否过期了?如果过期了此时就会删除。

采用定期删除+惰性删除就没其他问题了么?

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

在redis.conf中有一行配置

# maxmemory-policy volatile-lru

该配置就是配内存淘汰策略的(什么,你没配过?好好反省一下自己)

  • noeviction:当内存不足以容纳新写入数据时,新写入操作会报错。应该没人用吧。
  • allkeys-lru:当内存不足以容纳新写入数据时,在键空间中,移除最近最少使用的key。推荐使用,目前项目在用这种。
  • allkeys-random:当内存不足以容纳新写入数据时,在键空间中,随机移除某个key。应该也没人用吧,你不删最少使用Key,去随机删。
  • volatile-lru:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,移除最近最少使用的key。这种情况一般是把redis既当缓存,又做持久化存储的时候才用。不推荐
  • volatile-random:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,随机移除某个key。依然不推荐
  • volatile-ttl:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,有更早过期时间的key优先移除。不推荐

ps:如果没有设置 expire 的key, 不满足先决条件(prerequisites); 那么 volatile-lru, volatile-random 和 volatile-ttl 策略的行为, 和 noeviction(不删除) 基本上一致。

转载于:https://www.cnblogs.com/amunote/p/10447727.html

你可能感兴趣的文章
Application Virtualization 4.5 部署之四独立模式
查看>>
linux sed命令详解
查看>>
iPhone: 对象沿路径动画
查看>>
C#与Java的RSA(1)
查看>>
使用Filter时产生java.lang.IllegalStateException异常解决办法
查看>>
nginx的访问日志log用logrotate来做日志轮询
查看>>
HowTO:不用重装系统就地升级到更高 Windows 版本
查看>>
Server08 R2 Live Migration 测试 Part 5:Live Migration测试
查看>>
升级Exchange server 2010 SP1至SP3版本相关问题解决方法
查看>>
Python 数据库备份脚本(邮件通知)
查看>>
Struts2文件上传实例
查看>>
Liferay 从Dockbar 添加Portlet的事件细节研究
查看>>
Windows Server组策略应用顺序
查看>>
自己对精细化运维的理解
查看>>
以求医为例谈搜索引擎排序算法的基础原理
查看>>
网上Unused Index Script 脚本的问题
查看>>
数据仓库专题(2)-Kimball维度建模四步骤
查看>>
搞定微信告警-工具篇
查看>>
Objective-C的Block,递归与泛型
查看>>
inotify + rsync 打造文件实时同步
查看>>