当前位置: 首页 > news >正文

Redis除了做缓存还能做什么?

Redis 除了作为高性能缓存外,还因其丰富的数据结构和功能,广泛应用于多种场景。以下是 Redis 的十大核心用途及具体示例:


1. 分布式会话存储

  • 用途:存储用户会话信息(如登录状态),实现多服务间共享会话。
  • 优势:避免传统 Session 存储在单点故障或扩展性问题。
  • 数据结构:Hash(存储会话字段)、String(简单键值)。
  • 示例
    # 存储用户会话
    HSET user:session:1234 username "john" role "admin" expires 3600
    # 获取会话信息
    HGETALL user:session:1234
    

2. 分布式锁

  • 用途:实现跨服务的互斥锁,防止并发操作导致的数据不一致。
  • 核心命令SET key value NX PX 30000(原子操作 + 超时)。
  • 示例(防止重复下单):
    # 尝试获取锁(存在则失败)
    SET order_lock:1001 "locked" NX PX 10000
    # 释放锁(需结合Lua脚本保证原子性)
    if redis.call("get", KEYS[1]) == ARGV[1] then
        return redis.call("del", KEYS[1])
    else
        return 0
    end
    

3. 消息队列

  • 用途:实现轻量级消息队列,支持异步任务处理。
  • 数据结构:List(LPUSH/RPOP)、Stream(支持消费者组)。
  • 示例(使用 List):
    # 生产者推送任务
    LPUSH task_queue "send_email:user1@example.com"
    # 消费者获取任务
    RPOP task_queue
    

4. 实时排行榜

  • 用途:实时更新和查询排行榜(如游戏积分、商品销量)。
  • 数据结构:Sorted Set(按分数排序)。
  • 示例(游戏积分排行榜):
    # 添加玩家积分
    ZADD game_leaderboard 1500 "player1" 2000 "player2" 1800 "player3"
    # 获取前10名
    ZREVRANGE game_leaderboard 0 9 WITHSCORES
    

5. 计数器与限流

  • 用途:统计访问量、点赞数,或限制接口请求频率。
  • 核心命令INCRINCRBYEXPIRE
  • 示例(接口限流:每分钟最多100次请求):
    # 每次请求递增计数器
    INCR api_rate_limit:user123
    # 设置过期时间(首次设置时)
    EXPIRE api_rate_limit:user123 60
    # 检查是否超限
    GET api_rate_limit:user123  # 超过100则拒绝
    

6. 发布/订阅(Pub/Sub)

  • 用途:实现消息广播,支持实时通知(如聊天室、实时数据推送)。
  • 核心命令PUBLISHSUBSCRIBE
  • 示例(实时新闻推送):
    # 订阅频道
    SUBSCRIBE news_channel
    # 发布消息
    PUBLISH news_channel "Breaking: Redis 7.0 released!"
    

7. 地理位置服务

  • 用途:存储和查询地理位置(如附近的人、商家)。
  • 数据结构:GEO(基于 Sorted Set 实现)。
  • 示例(查找附近的餐厅):
    # 添加地理位置
    GEOADD restaurants 116.404269 39.913818 "restaurant_A"
    GEOADD restaurants 116.407531 39.915264 "restaurant_B"
    # 查找2公里内的餐厅
    GEORADIUS restaurants 116.405285 39.912987 2 km WITHDIST
    

8. 布隆过滤器(Bloom Filter)

  • 用途:高效判断元素是否存在(如防止缓存穿透、去重)。
  • 原理:基于概率的数据结构,占用空间极小。
  • 示例(校验新用户是否已注册):
    # 添加元素
    BF.ADD users "user123"
    # 检查是否存在
    BF.EXISTS users "user123"  # 返回1(可能存在)或0(一定不存在)
    

9. 实时数据分析

  • 用途:统计在线用户数、实时点击量等。
  • 数据结构:HyperLogLog(去重计数)、Bitmap(位操作)。
  • 示例(统计每日活跃用户):
    # 记录用户访问(用户ID为整型)
    SETBIT daily_active:20231001 1001 1
    # 统计总活跃用户数
    BITCOUNT daily_active:20231001
    

10. 数据库与缓存的二级存储

  • 用途:作为 MySQL 的二级存储,缓存复杂查询结果。
  • 模式:先查 Redis,未命中则查数据库并回填。
  • 示例(缓存商品详情):
    # 查询商品信息
    GET product:detail:1001
    # 未命中时从数据库加载并写入Redis
    SET product:detail:1001 '{"id":1001,"name":"Phone"}' EX 3600
    

总结

Redis 的多样化应用得益于其 高性能丰富的数据结构原子操作。合理使用 Redis 可以显著提升系统性能,解决分布式场景下的复杂问题。根据具体需求选择合适的数据结构和功能,是最大化 Redis 价值的关键。

http://www.dtcms.com/a/40947.html

相关文章:

  • springai系列(一):接入deepseek问答,扫坑记录
  • 猿大师播放器:HTML内嵌VLC播放RTSP视频流,无需转码,300ms级延迟,碾压服务器转码方案
  • 团队协作中的分支合并:构建高效开发流程的关键
  • 【笔记】论文阅读方法(AI大模型)
  • 半导体晶圆制造良率提升的指标体系设计
  • mapbox基础,使用geojson加载heatmap热力图层
  • 阿里巴巴 item_search 按关键字搜索商品开发应用指南
  • MOBA:长上下文 LLMs 的混合块注意机制
  • SOME/IP-SD -- 协议英文原文讲解7
  • 几个api
  • Windows 图形显示驱动开发-WDDM 3.2-自动显示切换(十)
  • MinIO在 Docker中修改登录账号和密码
  • 车床的应用场景
  • 【Excel】 Power Query抓取多页数据导入到Excel
  • 大模型智能体,企业股票量化投资分析工具
  • HTTP协议与RESTful API实战手册(二):用披萨店故事说透API设计奥秘 [特殊字符]
  • 批量给 Word 添加或设置页眉页脚/页码
  • 傅里叶分析
  • Java+Vue+uniapp微信小程序校园自助打印系统(程序+论文+讲解+安装+调试+售后)
  • DVWA -第二关-命令执行
  • Taylor龙哥库塔。各种稳定性
  • 李代数(Lie Algebras)与Attention:深度学习中的数学之美
  • Spring Cloud 的核心定义与定位
  • PMP项目管理—整合管理篇—3.指导与管理项目执行
  • 【Linux文件IO】系统IO和标准IO介绍
  • 具身智能(Embodied AI)的物理交互基准测试:构建真实世界的智能体评估体系
  • spring boot 2.7 + seata +微服务 降级失败问题修复
  • VSCode轻松调试运行C#控制台程序
  • 【C/C++】如何求出类对象的大小----类结构中的内存对齐
  • useLayoutEffect和useEffect有什么区别?