Redis第三弹,定时删除1.优先级队列(堆)2.基于时间轮实现的定时器​编辑Type指令(返回key对应的数据类型)redis的数据类型hset key field value

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: Redis第三弹,定时删除1.优先级队列(堆)2.基于时间轮实现的定时器​编辑Type指令(返回key对应的数据类型)redis的数据类型hset key field value

定时删除

redis并未实现定时器的方式,实现定时器的方式,实现过期key删除,若多个key过期,也可通过一个定时器(引入多线程这里的知识),来高效/节省。cpu的前提处理多个key

1.优先级队列(堆)

按指定的优先级,先出(自定义优先级)

在redis过期key的场景,就可通过,过期时间越早,优先级越高,现假定很多key设置了过期时间,把这些key加入到优先级队列中,指定优先级规则是过期时间早到先出队列。队首元素,就是最早要过期的key!

key1:12:00

key2:13:00

key3:14:00

(理论方案是可行的)此时定时器只要分配一个线程,让这个线程去检查队首元素,看是否过期即可!如果队首元素还没过期,那么后续元素一定没有过期。

扫描线程的时候:不需要遍历所有的key,只盯着这一个队首元素即可。

此时的做法:就是可以根据当前时刻和队首元素的过期时间,设置一个等待,当时间差不多到了,系统再去唤醒这个线程

扫描线程的时候,无需高频反复扫描队列,把cpu开销节省下来了,线程休眠,来了一个新的任务,11:30执行,我们可以当线程添加的时候,去唤醒线程,重新检查队首元素,再根据时间差,重新调整阻塞时间即可。

2.基于时间轮实现的定时器

虽然Redis都未采用,但是改进方式我们要去搞清楚

Type指令(返回key对应的数据类型)

redis的数据类型

none(不存在),string,list(列表),set(集合),zset(有序集合),hash,stream(当redis做消息队列的时候,使用这个类型)

hset key4 field value

hset key field value(这里是使用hash作为数据结构)

小结

由于Redis本事就是键值对结构,而他的hash更是键值对结构,所以这也就形成了嵌套的键值对。

为什么那个键是field,主要是为了和前面的key做出区分。

在Redis中,上述类型操作方式差别很大,使用的命令都是完全相同的。

lpush key2 111 222 333

keys :用来匹配规则的key

exist:判定指定的key是否存在

del:删除指定key

exprie:给key设置过期时间

ttl:查询key的过期时间

type:查询当前key的类型


相关文章
|
9月前
|
canal NoSQL 关系型数据库
Redis应用—7.大Value处理方案
本文介绍了一种用于监控Redis大key的方案设计及其实现步骤。主要内容包括:方案设计、安装与配置环境、binlog数据消费者。
347 29
Redis应用—7.大Value处理方案
|
5月前
|
存储 NoSQL 定位技术
Redis数据类型面试给分情况
Redis常见数据类型包括:string、hash、list、set、zset(有序集合)。此外还包含高级结构如bitmap、hyperloglog、geo。不同场景可选用合适类型,如库存用string,对象存hash,列表用list,去重场景用set,排行用zset,签到用bitmap,统计访问量用hyperloglog,地理位置用geo。
126 5
|
5月前
|
NoSQL Java Redis
Redis基本数据类型及Spring Data Redis应用
Redis 是开源高性能键值对数据库,支持 String、Hash、List、Set、Sorted Set 等数据结构,适用于缓存、消息队列、排行榜等场景。具备高性能、原子操作及丰富功能,是分布式系统核心组件。
574 2
|
9月前
|
缓存 NoSQL Java
Redis应用—6.热key探测设计与实践
热key问题在高并发系统中可能导致数据层和服务层的严重瓶颈,如Redis集群瘫痪和用户体验下降。为解决此问题,京东开发了JdHotkey热key探测框架,具备实时性、准确性、集群一致性和高性能等特点。该框架由etcd集群、Client端jar包、Worker端集群和Dashboard控制台组成,通过分布式计算快速识别热key并推送至应用内存,有效减轻数据层负载,提升服务性能。JdHotkey适用于多种场景,安装部署简便,支持毫秒级热key探测和集群一致性维护。
443 61
Redis应用—6.热key探测设计与实践
|
6月前
|
NoSQL 测试技术 Redis
Redis批量删除Key的三种方式
Redis批量删除Key是优化数据库性能的重要操作,本文介绍三种高效方法:1) 使用通配符匹配(KEYS/SCAN+DEL),适合不同数据规模;2) Lua脚本实现原子化删除,适用于需要事务保障的场景;3) 管道批量处理提升效率。根据实际需求选择合适方案,注意操作不可逆,建议先备份数据,避免内存溢出或阻塞。
|
12月前
|
存储 缓存 NoSQL
解决Redis缓存数据类型丢失问题
解决Redis缓存数据类型丢失问题
447 85
|
9月前
|
NoSQL Redis
Redis的常用数据类型有哪些 ?
Redis 有 5 种基础数据结构,它们分别是:string(字符串)、list(列表)、hash(字典)、set(集 合) 和 zset(有序集合)
|
11月前
|
NoSQL API Redis
在C程序中实现类似Redis的SCAN机制的LevelDB大规模key分批扫描
通过上述步骤,可以在C程序中实现类似Redis的SCAN机制的LevelDB大规模key分批扫描。利用LevelDB的迭代器,可以高效地遍历和处理数据库中的大量键值对。该实现方法不仅简单易懂,还具有良好的性能和扩展性,希望能为您的开发工作提供实用的指导和帮助。
174 7
|
7月前
|
缓存 NoSQL 关系型数据库
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
美团面试:MySQL有1000w数据,redis只存20w的数据,如何做 缓存 设计?
|
2月前
|
缓存 负载均衡 监控
135_负载均衡:Redis缓存 - 提高缓存命中率的配置与最佳实践
在现代大型语言模型(LLM)部署架构中,缓存系统扮演着至关重要的角色。随着LLM应用规模的不断扩大和用户需求的持续增长,如何构建高效、可靠的缓存架构成为系统性能优化的核心挑战。Redis作为业界领先的内存数据库,因其高性能、丰富的数据结构和灵活的配置选项,已成为LLM部署中首选的缓存解决方案。