首页 > 数据库 >小小Redis数据删除策略,拿捏

小小Redis数据删除策略,拿捏

时间:2024-05-21 18:31:22浏览次数:26  
标签:小小 删除 过期 expires Redis 拿捏 key 数据

Redis的删除策略

水一篇


Redis是一种内存级数据库,所有数据均存放在内存中,内存中的数据可以通过TTL指令获取其状态

TTL返回的值有三种情况:正数,-1,-2

  • 正数:代表该数据在内存中还能存活的时间
  • -1:永久有效的数据
  • -2 :已经过期的数据 或被删除的数据 或 未定义的数据

删除策略就是针对已过期数据的处理策略

redis的删除策略:

1. 定时删除:

创建一个定时器,当key设置有过期时间,且过期时间到达时,由定时器任务立即执行对键的删除操作

2. 惰性删除:

数据到达过期时间,不做处理。等下次访问该数据时,我们需要判断

  • 如果未过期,返回数据

  • 发现已过期,删除,返回不存在(调用expireIfneeded())

3. 定期删除:

定期删除就是周期性轮询redis库中的时效性数据,采用随机抽取的策略,利用过期数据占比的方式控制删除频度

我自己理解的定期删除就是 把redis存储分成几个区,起名叫expires区,循环这几个区,每到一个区随机抓一把(W个,W可自定义)数据把里面过期的删了,删除的数量大于一个阈值就再抓一把数据删,直到小于阈值;就去下一个分区执行这个操作

具体执行过程:

  • Redis启动服务器初始化时,读取配置server.hz的值,默认为10

  • 每秒钟执行server.hz次serverCron()-------->databasesCron()--------->activeExpireCycle()

  • activeExpireCycle()对每个expires[*]逐一进行检测,每次执行耗时:250ms/server.hz

  • 对某个expires[*]检测时,随机挑选W个key检测

  如果key超时,删除key

  如果一轮中删除的key的数量>W*25%,循环该过程

  如果一轮中删除的key的数量≤W*25%,检查下一个expires[*],0-15循环

  W取值=ACTIVE_EXPIRE_CYCLE_LOOKUPS_PER_LOOP属性值
  • 参数current_db用于记录activeExpireCycle() 进入哪个expires[*] 执行

  • 如果activeExpireCycle()执行时间到期,下次从current_db继续向下执行

幻想自己是个超市杂粮区卖豆子的,抓一把豆子把坏的扔了,坏的不多就过了,坏的太多就再抓一把豆子筛,黑心店家

标签:小小,删除,过期,expires,Redis,拿捏,key,数据
From: https://www.cnblogs.com/always-uie/p/18204719

相关文章

  • 一些好用的css小小属性,拿下拿下!!
    CSSwriting-mode属性它是用于垂直排版的语言,比如中文或者日文。然而,有趣的是如果我们把它用在英语中,可以很方便的创建垂直文本。(writing-mode属性定义了文字在文文字块中垂直或者水平方向,参考MDN。)horizontal-tb:水平方向自上而下的书写方式。即left-right-top-bottom......
  • spring boot集成redis
    Redis是一个开源的使用ANSIC语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API。支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)、zset(sortedset--有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add......
  • 一次redis和内存的qps比较
    不同缓存策略下的性能指标:无缓存|Redis|直接内存1.无缓存测试结果2.加入Redis缓存后性能翻倍6-73.直接用内存(错误写法)错误写法的性能指标正确写法(双检单例模式)正确写法后,性能......
  • 让redis集成到django的库--django-redis
    安装pipinstalldjango-redis配置作为cachebackend使用配置为了使用django-redis,你应该将你的djangocachesetting改成这样:CACHES={"default":{"BACKEND":"django_redis.cache.RedisCache","LOCATION":"r......
  • python操作redis数据库
    官方文档https://redis.io/docs/latest/develop/connect/clients/python/仓库https://github.com/redis/redis-py安装库pipinstallredis普通连接r=redis.Redis(host='10.0.0.5',port=6379,decode_responses=True)decode_responses表示响应的结果是解码后的......
  • redis 网络库
    APIintanetTcpConnect(char*err,char*addr,intport);intanetTcpNonBlockConnect(char*err,char*addr,intport);intanetUnixConnect(char*err,char*path);intanetUnixNonBlockConnect(char*err,char*path);intanetRead(intfd,char*buf,intcount......
  • Redis 缓存常见问题处理
    缓存穿透缓存穿透是指客户端的请求数据在缓存和数据库中都不存在,这样缓存永远不会生效,这些请求都会到达数据库,从而导致数据库负载过高。常见解决方案有两种:缓存空对象:实现简单、方便维护,是解决缓存穿透的首选方法,但会造成额外内存消耗,或短期的数据不一致布隆过滤:内存占用少,没......
  • redis存储之序列化问题
    1.问题描述:在SpringBoot集成Redis过程中,添加进redisf的内容如下2.出现这种情况的原因(1) 键和值都是通过Spring提供的Serializer序列化到数据库的(2) RedisTemplate默认使用的是JdkSerializationRedisSerializer,StringRedisTemplate默认使用的是StringRedisSerializer3.解......
  • Redis内存回收与缓存问题
    内存回收:1.过期key处理通过expire命令给key设置ttlRedis本身是KV型数据库,所有数据都存在RedisDB结构体中,其中有两张哈希表dict:用于存放KV(这里K是K,V是V)expires:保存Redis中所有的设置了过期时间的KEY以及到期时间TTL(这里K是K,V是TTL)过期KEY有两种删除策略:惰性删除,有......
  • Redis的缓存雪崩、击穿、穿透问题,小小缓存问题,拿捏
    前言来整理一下缓存雪崩、击穿和穿透的问题,这个问题在面试中常出现,不是瞎说,我已经遇到几次了一、缓存雪崩1.雪崩什么是雪崩,某度给出的解释雪崩当山坡积雪内部的内聚力抗拒不了它所受到的重力拉引时,便向下滑动,引起大量雪体崩塌,人们把这种自然现象称作雪崩。说白了就......