Redis 通常应用于哪些场景?

Redis 本质上是一个高性能内存数据库(key-value) ,特点是:快(微秒级)、支持多种数据结构、支持持久化和分布式。所以它常用于一些"对性能要求高、读写频繁"的场景。


一、缓存(最核心场景)

👉 90% 的 Redis 使用都是做缓存

用法:

  • 查询数据库 → 放入 Redis
  • 下次直接从 Redis 读

典型场景:

  • 商品详情页
  • 用户信息
  • 配置数据

解决的问题:

  • 减轻数据库压力
  • 提高响应速度(毫秒 → 微秒)

二、分布式锁

👉 多服务/多线程抢资源时用

用法:

  • 利用 SETNXSET key value NX EX

场景:

  • 秒杀系统(防止超卖)
  • 定时任务只执行一次
  • 防止重复提交

三、计数器(高并发统计)

👉 Redis 原子操作非常适合计数

用法:

  • INCR / DECR

场景:

  • 点赞数
  • 浏览量(PV)
  • 接口访问次数(限流基础)

四、排行榜 / 排序

👉 使用 有序集合(ZSet)

场景:

  • 游戏积分排行榜
  • 热门文章排序
  • 热搜榜

特点:

  • 自动排序
  • 支持按分数范围查询

五、消息队列(轻量 MQ)

👉 Redis 也能做简单队列

用法:

  • List:LPUSH + RPOP
  • Stream(更专业)

场景:

  • 异步处理(下单后发短信)
  • 削峰填谷(高并发缓冲)

但复杂场景一般用 Kafka / RabbitMQ


六、Session 共享(登录状态)

👉 分布式系统必用

场景:

  • 多台服务器共享登录状态

原理:

  • 用户登录信息存 Redis
  • 所有服务都能访问

七、限流(防刷接口)

👉 常用在网关/接口层

实现方式:

  • 计数 + 过期时间
  • 滑动窗口(ZSet)

场景:

  • 登录接口限制
  • 短信验证码发送限制
  • API 防攻击

八、地理位置(LBS)

👉 Redis 自带 GEO

场景:

  • 附近的人
  • 附近的店铺
  • 外卖/打车

九、缓存热点数据(热点Key)

👉 高并发系统常见问题

场景:

  • 热门商品
  • 秒杀商品
  • 首页推荐

十、布隆过滤器(防缓存穿透)

👉 避免无效查询打到数据库

场景:

  • 查询不存在的数据(恶意攻击)
  • 大规模ID校验

总结一句话(面试用🔥)

👉
Redis 主要用于:缓存、分布式锁、计数器、排行榜、消息队列、Session共享、限流、地理位置等高并发、高性能场景。


再给你一个"程序员思维版总结"

如果你写系统,可以这么理解:

  • 读多写少 → 用 Redis 做缓存
  • 抢资源 → 用 Redis 锁
  • 统计数据 → 用 Redis 计数
  • 需要排序 → 用 ZSet
  • 异步削峰 → 用 Redis 队列
  • 分布式登录 → 用 Redis 存 Session

相关推荐
m0_748554814 小时前
如何用 stopPropagation 阻止事件冒泡防止触发父级回调
jvm·数据库·python
2301_812539674 小时前
SQL如何基于窗口函数实现复杂分层 DENSE_RANK应用
jvm·数据库·python
weixin_459753944 小时前
Go语言怎么做多阶段构建_Go语言Docker多阶段构建教程【完整】
jvm·数据库·python
m0_631529824 小时前
MySQL如何解决锁等待超时异常_捕获MySQL Error 1205错误
jvm·数据库·python
qq_392690664 小时前
如何防止MongoDB副本集被误初始化_副本集名称(replSetName)锁定
jvm·数据库·python
m0_748554814 小时前
Go 中调用纯函数的并发安全性详解
jvm·数据库·python
m0_740653224 小时前
SQL如何利用聚合函数进行库存预测_历史数据分组汇总
jvm·数据库·python
2301_787312434 小时前
如何利用宝塔面板设置网站限流策略_防止恶意高并发请求
jvm·数据库·python
科技小花4 小时前
AI原生 vs 云原生:数据治理平台选型如何匹配你的数据中台架构?
大数据·数据库·人工智能·数据治理·数据中台
m0_733565464 小时前
SQL如何统计各分组下指标的波动率_STDDEV聚合函数应用
jvm·数据库·python