Redis的过期策略和内存淘汰策略不要搞混淆

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

阅读文本大概需要8分钟。

0x01Redis的过期策略

Redis是key-value数据库在程序中可以设置Redis中缓存的key的过期时间。Redis的过期策略就是指当Redis中缓存的key过期了以后Redis是如何处理的。

过期策略通常有以下三种

定时过期每个设置过期时间的key都需要创建一个定时器到过期时间就会立即清除。该策略可以立即清除过期的数据对内存很友好但是会占用大量的CPU资源去处理过期的数据从而影响缓存的响应时间和吞吐量。

惰性过期只有当访问一个key时才会判断该key是否已过期过期则清除。该策略可以最大化地节省CPU资源却对内存非常不友好。极端情况可能出现大量的过期key没有再次被访问从而不会被清除占用大量内存。

定期过期每隔一定的时间会扫描一定数量的数据库的expires字典中一定数量的key并清除其中已过期的key。该策略是前两者的一个折中方案。通过调整定时扫描的时间间隔和每次扫描的限定耗时可以在不同情况下使得CPU和内存资源达到最优的平衡效果。(expires字典会保存所有设置了过期时间的key的过期时间数据其中key是指向键空间中的某个键的指针value是该键的毫秒精度的UNIX时间戳表示的过期时间。键空间是指该Redis集群中保存的所有键。)

Redis同时使用了惰性过期和定期过期两种过期策略。但是Redis定期删除是随机抽取机制不可能扫描删除掉所有的过期Key。因此需要内存淘汰机制。

0x02Redis的内存淘汰策略

Redis的内存淘汰策略是指在Redis的用于缓存的内存不足时怎么处理需要新写入且需要申请额外空间的数据。

no-eviction当内存不足以容纳新写入数据时新写入操作会报错。

allkeys-lru当内存不足以容纳新写入数据时在键空间中移除最近最少使用的key。

allkeys-random当内存不足以容纳新写入数据时在键空间中随机移除某个key。

volatile-lru当内存不足以容纳新写入数据时在设置了过期时间的键空间中移除最近最少使用的key。

volatile-random当内存不足以容纳新写入数据时在设置了过期时间的键空间中随机移除某个key。

volatile-ttl当内存不足以容纳新写入数据时在设置了过期时间的键空间中有更早过期时间的key优先移除。

0x03总结

Redis的内存淘汰策略的选取并不会影响过期的key的处理。内存淘汰策略用于处理内存不足时的需要申请额外空间的数据过期策略用于处理过期的缓存数据。

过期键删除策略和内存淘汰机制之间的关系

  • 过期健删除策略强调的是对过期健的操作如果有健过期了而内存还足够不会使用内存淘汰机制这时也会使用过期健删除策略删除过期健。
  • 内存淘汰机制强调的是对内存的操作如果内存不够了即使有的健没有过期也要删除一部分同时也针对没有设置过期时间的健。

参考来源https://www.cnblogs.com/zyy1688/p/10456446.html

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
标签: redis