延迟消息队列

利用 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 得出结果

转载于:https://www.cnblogs.com/Piers/p/11087370.html

Redis 一些高级用法相关推荐

  1. Redis 集合高级用法

    前言 不知你大规模的用过Redis吗?还是仅仅作为缓存的工具了?在Redis中使用最多的就是集合了,举个例子,如下场景: 签到系统中,一天对应一系列的用户签到记录. 电商系统中,一个商品对应一系列的评 ...

  2. redis php高级使用_项目中应用Redis+Php的场景

    前言 一些案例中有的同学说为什么不可以用string类型,string类型完全可以实现呀 我建议你看下我的专栏文章<Redis高级用法>,里面介绍了用hash类型的好处 商品维度计数 对商 ...

  3. Python多线程多进程、异步、异常处理等高级用法

    文章目录 前言 多线程多进程 多线程 多进程 协程 总结 异步 基本概念 异步编程 asyncio aiohttp 异常 常见异常 异常处理 自定义异常 lambda表达式 lambda表达式用法 高 ...

  4. vim的高级用法配置以及在系统中如何获取帮助

    vim的高级用法配置以及在系统中如何获取帮助 1 vim的三种模式 1.1 使用方法 1.2 vim模式 2 vim工作的基本配置 2.1 临时设定(set设定) 2.2 永久设定方式 3 搜索 4 ...

  5. Cacti Weathermap 高级用法 (二)

    成都长宽Weathermap实际运用的效果图示例: 这是一个CNC出口的质量监控图. 途中cnc节点(红色)是一个展示图例,TEL节点根据存活状态显示为绿色 TEL节点上面P:47.2ms 是一个,这 ...

  6. JAVA正则表达式高级用法(分组与捕获)

    2019独角兽企业重金招聘Python工程师标准>>> 正则表达式在字符串处理中经常使用,关于正则简单的用法相信有一点程序基础的人都懂得一些,这里就不介绍简单基础了.这里主要讲解一下 ...

  7. GUN sed高级用法,sed脚本编写

    这里举一些sed常用的高级用法例子经供参考: 一下操作都针对file.txt文件作修改 [root@QX-××× ~]# cat file.txt libgcc-4.4.7-4.el6.x86_64 ...

  8. java return用法_Java枚举的高级用法之多键值的映射使用

    枚举Enum单映射使用 做Java的各位仁兄姐妹都知道,Java通过HashMap,以及枚举提供了方便的K-V映射功能,例如 枚举单映射使用 但是如果遇到多个键值映射,例如K-K-V的形式怎么办呢?可 ...

  9. (转)python requests 高级用法 -- 包括SSL 证书错误的解决方案

    (转)python requests 高级用法 -- 包括SSL 证书错误的解决方案 参考文章: (1)(转)python requests 高级用法 -- 包括SSL 证书错误的解决方案 (2)ht ...

最新文章

  1. python定义一个汽车类_汽车类Python程序
  2. 瞄准医疗数据安全四大风险 东软DBA如何绝地阻击
  3. Mybatis打印调试sql的两种方式
  4. 脑机接口成唯一沟通方式,渐冻症晚期父亲终向4岁儿子表达爱意
  5. 思维题——倒序差分的运用
  6. c语言 srand time 0,c++ 随机数 srand(time(0)) 用法 | 求索阁
  7. 移动端真机测试怎么做
  8. Leetcode--837. 新21点(java)
  9. Linux移植随笔:对tslib库的ts_test测试程序代码的一点分析
  10. Python Debug调试技巧
  11. python sendline,python pexpect sendcontrol关键字符
  12. 《AutoCAD 2014中文版实用教程》一一2.2 圆类命令
  13. js记录访问网页的ip_亚马逊新手记录之避免店铺关联
  14. 碰到的TypeError--记录
  15. 大数据技术原理与应用学习笔记(九)
  16. LTE系统中的OFDM技术
  17. quartz定时任务框架
  18. md5加密算法使用流程
  19. linux终端里面的光标很粗,怎么调细
  20. 感恩节“谢谢”英文怎么说

热门文章

  1. ISO时间转化时间戳
  2. HTML引入第三方类库项目需要授权解决方案
  3. JAVA爬虫Jsoup,抓取房价
  4. Vue项目中公用footer组件底部位置的适配问题
  5. Apache引起的wampserver安装好第二次使用无法启动问题
  6. CNN结构:场景分割与Relation Network
  7. cachehelper java,初识EHCache缓存框架(2.x版本)
  8. protobuf版本冲突
  9. 《计算机科学与工程导论:基于IoT和机器人的可视化编程实践方法第2版》一1.2.2 团队组建...
  10. 从Javascript单线程谈Event Loop