面试-Redis常见场景

1.从海量的数据里查询某一固定前缀的key

(1)keys pattern指令:

摸清数据规模(很重要)

(2)cursor:游标

Scan cursor [MATCH pattern] [COUNT count]

可以无阻塞的提取出指定模式的key列表

基于游标的迭代器,需要基于上一次的游标延续之前的迭代过程。

以0作为游标开始一次新的迭代,直到命令返回游标为0完成一次遍历

不保证每次执行都需要返回某个给定数量的元素,支持模糊查询

一次返回数量不可控,只能是大概率符合count参数

2.如何通过redis实现分布式锁

分布式锁:是控制分布式系统或不同系统之间共同访问共享资源的一种锁的实现。

分布式锁需要解决的问题:

互斥性;安全性;死锁;容错;

原子性操作。用来实现分布式锁。在执行某段代码逻辑时,先使用SETNX对某个key设值,设置成功表示没有别的线程在执行该段代码。反之,就有别的线程正在占用该段资源。

如何解决SETNX长期有效的问题?

expire key seconds

设置key的生存时间,当key过期时(生存时间为0),会自动删除

优化:从Redis 2. 6.12开始可以将SETNX和expire结合。

3.如何实现异步队列:

使用list作为队列,RPUSH生产消息,LPOP消费消息。

缺点:没有等待队列里有值就直接消费

弥补:可以通过在应用层引入Sleep机制去调用LPOP重试。

BlPOP能代替sleep做更精准的阻塞控制。


缺点:消息的发布是无状态的,无法保证可达。

对于发布者来说消息是即发即失的。若消费者在生产者发布消息时下线,重新上线时是接收不到该消息的。要解决这个问题,就要使用专业的消息队列。如Kafka,rabbitMQ

相关推荐
en-route40 分钟前
Spring 框架下 Redis 会话存储应用实践
java·redis·spring
小明的小名叫小明44 分钟前
区块链核心知识点梳理(面试高频考点2)-BTC vs ETH vs Solana 账户模型对比
面试·区块链
想用offer打牌1 小时前
JDK动态代理为什么基于接口而不基于类?
java·后端·面试
愤怒的代码1 小时前
第 4 篇:HashMap 深度解析(JDK1.7 vs JDK1.8、红黑树、扩容逻辑)(5 题)
java·面试
用户12039112947261 小时前
从原生 JS 到 Vue3 Composition API:手把手教你用现代 Vue 写一个优雅的 Todos 任务清单
前端·vue.js·面试
sugarzhangnotes1 小时前
应用服务OOM引发GC异常,导致Redis请求超时失败的问题分析与解决
数据库·redis·测试工具
gis分享者1 小时前
2023A卷,完美走位
面试·2023·真题·a·完美·走位·解答
小满、1 小时前
Redis:数据结构与基础操作(String、List、Hash、Set、Sorted Set)
java·数据结构·redis·分布式锁
zjeweler1 小时前
redis tools gui ---Redis图形化漏洞利用工具
数据库·redis·web安全·缓存
武子康2 小时前
Java-192 深入拆解 EVCache 内部原理:Memcached 架构、Slab 分配与 LRU 过期机制全解析
数据库·redis·缓存·架构·memcached·guava·evcache