zoukankan      html  css  js  c++  java
  • Redis 一些高级用法

    延迟消息队列

    利用 expire keyspace notification

    Redis 过期时,会向特定的消息队列发送消息,监听该消息队列

    • 在 redis.conf 修改 notify-keyspace-events "Ex",重启 Redis;或者直接利用 config set notify-keyspace-events "Ex"
    • 设置定时任务的 key,key 包含了你在过期那一刻所需要的所有数据
    • psubscribe keyspace@*:expired,* 为所有数据库
    • 过期会收到 key,处理

    优点:

    • 很直观,简单粗暴
    • 性能相对于 Sorted Set 版本高,不用轮询

    缺点:

    • 如果没人监听队列,数据就丢了,比如重启服务器的情况
    • 消息重复需要处理

    Sorted Set,用时间戳作为 Score

    Sorted Set,用时间戳作为 Score,Member 为你想处理的数据内容

    • 设置定时任务,ZAdd,Member 为数据,Score 为定时任务需要执行时刻的时间戳
    • 每隔一段时间轮询该 Sorted Set,最大值为当前时间戳,ZRangeByScore key -inf curTimestamp
    • 取出来的值,记得立刻删除,再做处理

    优点:

    • 不会丢数据

    缺点:

    • 由于轮询性能有损耗(不能说低)
    • 需要做并发控制,多个实例同时轮询到相同的数据

    Tip: 删除返回行数为 0 时,可以认为已经被别人处理;同时,可以 sleep 一些时间,使得不同服务器执行定时任务的时间错开,类似于拥塞控制

    消息队列

    让我想一想

    搜索引擎

    反向索引

    分布式锁

    首先加锁必须是原子的,释放锁必须要有定时机制,所以满足条件一般采用 setnx lock EX 1

    综合评分系统

    比如一门考试,课程 A 分数高优先录取(分数范围 0 - 1000),课程 B 分数高第二录取(分数范围 0 - 100),加入存了两个 Sorted Set,分别为 ScoreA 和 Score B,那么怎么求出最高分方便?

    总分评价 = A * 1000 + B,用 Redis 就是 ZUnionStore 得出结果

  • 相关阅读:
    各种数据库查询表及表信息的SQL
    多维表头的DataGridView
    SQLite入门笔记
    配置WCF的心得
    JS键盘的键码
    ASP.NET的URL过滤
    利用反射查看类成员
    一个简单的MVC示例
    一个日志类 LogUtil
    一个IniHelper
  • 原文地址:https://www.cnblogs.com/Piers/p/11087370.html
Copyright © 2011-2022 走看看