浅谈Redis的几个过期策略


Posted in Redis onMay 27, 2021

概述

设置过期时间

expire key time(以秒为单位) 这是最常用的方式
setex(String key, int seconds, String value) 字符串独有的方式
除了字符串自己独有设置过期时间的方法外,其他方法都需要依靠expire方法来设置时间如果没有设置时间,那缓存就是永不过期如果设置了过期时间,之后又想让缓存永不过期,使用persist key

三种过期策略

定时删除

在设置key的过期时间的同时,为该key创建一个定时器,让定时器在key的过期时间来临时,对key进行删除

优点:

保证内存被尽快释放

缺点:

若过期key很多,删除这些key会占用很多的CPU时间,在CPU时间紧张的情况下,CPU不能把所有的时间用来做要紧的事儿,还需要去花时间删除这些key
定时器的创建耗时,若为每一个设置过期时间的key创建一个定时器(将会有大量的定时器产生),性能影响严重

懒汉式式删除

key过期的时候不删除,每次通过key获取值的时候去检查是否过期,若过期,则删除,返回null。

优点:

删除操作只发生在通过key取值的时候发生,而且只删除当前key,所以对CPU时间的占用是比较少的,而且此时的删除是已经到了非做不可的地步(如果此时还不删除的话,我们就会获取到了已经过期的key了)

缺点:

若大量的key在超出超时时间后,很久一段时间内,都没有被获取过,那么可能发生内存泄露(无用的垃圾占用了大量的内存)

定期删除

每隔一段时间执行一次删除过期key操作

优点:

通过限制删除操作的时长和频率,来减少删除操作对CPU时间的占用--处理"定时删除"的缺点
定期删除过期key--处理"懒汉式删除"的缺点

缺点:

在内存友好方面,不如"定时删除"(会造成一定的内存占用,但是没有懒汉式那么占用内存)
在CPU时间友好方面,不如"懒汉式删除"(会定期的去进行比较和删除操作,cpu方面不如懒汉式,但是比定时好)

难点:

合理设置删除操作的执行时长(每次删除执行多长时间)和执行频率(每隔多长时间做一次删除)(这个要根据服务器运行情况来定了),每次执行时间太长,或者执行频率太高对cpu都是一种压力。
每次进行定期删除操作执行之后,需要记录遍历循环到了哪个标志位,以便下一次定期时间来时,从上次位置开始进行循环遍历

说明:

memcached只是用了惰性删除,而redis同时使用了惰性删除与定期删除,这也是二者的一个不同点(可以看做是redis优于memcached的一点);

对于懒汉式删除而言,并不是只有获取key的时候才会检查key是否过期,在某些设置key的方法上也会检查(eg.setnx key2 value2:该方法类似于memcached的add方法,如果设置的key2已经存在,那么该方法返回false,什么都不做;如果设置的key2不存在,那么该方法设置缓存key2-value2。假设调用此方法的时候,发现redis中已经存在了key2,但是该key2已经过期了,如果此时不执行删除操作的话,setnx方法将会直接返回false,也就是说此时并没有重新设置key2-value2成功,所以对于一定要在setnx执行之前,对key2进行过期检查)。

Redis采用的过期策略

懒汉式删除+定期删除

懒汉式删除流程:

在进行get或setnx等操作时,先检查key是否过期;
若过期,删除key,然后执行相应操作;
若没过期,直接执行相应操作;
定期删除流程
简单而言,对指定个数个库的每一个库随机删除小于等于指定个数个过期key

遍历每个数据库(就是redis.conf中配置的"database"数量,默认为16)
检查当前库中的指定个数个key(默认是每个库检查20个key,注意相当于该循环执行20次,循环体是下边的描述)
如果当前库中没有一个key设置了过期时间,直接执行下一个库的遍历
随机获取一个设置了过期时间的key,检查该key是否过期,如果过期,删除key
判断定期删除操作是否已经达到指定时长,若已经达到,直接退出定期删除。
对于定期删除,在程序中有一个全局变量currentdb来记录下一个将要遍历的库,假设有16个库,我们这一次定期删除遍历了10个,那此时的currentdb就是11,下一次定期删除就从第11个库开始遍历,假设currentdb等于15了,那么之后遍历就再从0号库开始(此时currentdb==0)

总结

在实际中,如果我们要自己设计过期策略,在使用懒汉式删除+定期删除时,控制时长和频率这个尤为关键,需要结合服务器性能,已经并发量等情况进行调整,以致最佳。

以上就是浅谈Redis的几个过期策略的详细内容,更多关于Redis的几个过期策略的资料请关注三水点靠木其它相关文章!

Redis 相关文章推荐
redis连接被拒绝的解决方案
Apr 12 Redis
redis通过6379端口无法连接服务器(redis-server.exe闪退)
May 08 Redis
基于Redis过期事件实现订单超时取消
May 08 Redis
redis哨兵常用命令和监控示例详解
May 27 Redis
Redis Cluster集群动态扩容的实现
Jul 15 Redis
Redis做数据持久化的解决方案及底层原理
Jul 15 Redis
为什么RedisCluster设计成16384个槽
Sep 25 Redis
CentOS8.4安装Redis6.2.6的详细过程
Nov 20 Redis
聊聊redis-dump工具安装问题
Jan 18 Redis
Redis基本数据类型Zset有序集合常用操作
Jun 01 Redis
使用Redis实现分布式锁的方法
Jun 16 Redis
Redis过期数据是否会被立马删除
Jul 23 Redis
Redis Cluster 字段模糊匹配及删除
May 27 #Redis
redis哨兵常用命令和监控示例详解
May 27 #Redis
Java Socket实现Redis客户端的详细说明
May 26 #Redis
redis实现共同好友的思路详解
详解Redis瘦身指南
May 26 #Redis
Redis高级数据类型Hyperloglog、Bitmap的使用
May 24 #Redis
redis实现排行榜功能
May 24 #Redis
You might like
PHP安全编程之加密功能
2006/10/09 PHP
php中mysql操作buffer用法详解
2015/03/19 PHP
Js 获取当前日期时间及其它操作实现代码
2021/03/04 Javascript
JS 获取浏览器和屏幕宽高等信息的实现思路及代码
2013/07/31 Javascript
Javascript 实现的数独解题算法网页实例
2013/10/15 Javascript
运用JQuery的toggle实现网页加载完成自动弹窗
2014/03/18 Javascript
JQuery 图片滚动轮播示例代码
2014/03/24 Javascript
js判断一个字符串是否包含一个子串的方法
2015/01/26 Javascript
JavaScript使用指针操作实现约瑟夫问题实例
2015/04/07 Javascript
JS实现的自定义网页拖动类
2015/11/06 Javascript
实例详解jQuery Mockjax 插件模拟 Ajax 请求
2016/01/12 Javascript
jquery分页插件jquery.pagination.js使用方法解析
2016/04/01 Javascript
基于Jquery插件实现跨域异步上传文件功能
2016/04/26 Javascript
AngularJS中$http服务常用的应用及参数
2016/08/22 Javascript
Javascript 实现微信分享(QQ、朋友圈、分享给朋友)
2016/10/21 Javascript
jquery 多个radio的click事件实例
2016/12/03 Javascript
Bootstrap警告框(Alert)插件使用方法
2017/03/21 Javascript
Vue的Class与Style绑定的方法
2017/09/01 Javascript
echarts学习笔记之箱线图的分析与绘制详解
2017/11/22 Javascript
Vue项目报错:Uncaught SyntaxError: Unexpected token
2018/11/10 Javascript
详解vue中async-await的使用误区
2018/12/05 Javascript
vue+高德地图写地图选址组件的方法
2019/05/18 Javascript
vue中keep-alive,include的缓存问题
2019/11/26 Javascript
python实现查询苹果手机维修进度
2015/03/16 Python
Django框架设置cookies与获取cookies操作详解
2019/05/27 Python
python之pymysql模块简单应用示例代码
2019/12/16 Python
Tensorflow 1.0之后模型文件、权重数值的读取方式
2020/02/12 Python
python实现五子棋程序
2020/04/24 Python
Python Request类源码实现方法及原理解析
2020/08/17 Python
什么样的创业计划书可行性高?
2014/02/01 职场文书
《浅水洼里的小鱼》听课反思
2014/02/28 职场文书
2015年感恩节活动总结
2015/03/24 职场文书
装配车间主任岗位职责
2015/04/08 职场文书
2015年秋季小学开学典礼主持词
2015/07/16 职场文书
会议室使用管理制度
2015/08/06 职场文书
2019年圣诞节祝福语集锦
2019/12/25 职场文书