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 得出结果
转载于:https://www.cnblogs.com/Piers/p/11087370.html
Redis 一些高级用法相关推荐
- Redis 集合高级用法
前言 不知你大规模的用过Redis吗?还是仅仅作为缓存的工具了?在Redis中使用最多的就是集合了,举个例子,如下场景: 签到系统中,一天对应一系列的用户签到记录. 电商系统中,一个商品对应一系列的评 ...
- redis php高级使用_项目中应用Redis+Php的场景
前言 一些案例中有的同学说为什么不可以用string类型,string类型完全可以实现呀 我建议你看下我的专栏文章<Redis高级用法>,里面介绍了用hash类型的好处 商品维度计数 对商 ...
- Python多线程多进程、异步、异常处理等高级用法
文章目录 前言 多线程多进程 多线程 多进程 协程 总结 异步 基本概念 异步编程 asyncio aiohttp 异常 常见异常 异常处理 自定义异常 lambda表达式 lambda表达式用法 高 ...
- vim的高级用法配置以及在系统中如何获取帮助
vim的高级用法配置以及在系统中如何获取帮助 1 vim的三种模式 1.1 使用方法 1.2 vim模式 2 vim工作的基本配置 2.1 临时设定(set设定) 2.2 永久设定方式 3 搜索 4 ...
- Cacti Weathermap 高级用法 (二)
成都长宽Weathermap实际运用的效果图示例: 这是一个CNC出口的质量监控图. 途中cnc节点(红色)是一个展示图例,TEL节点根据存活状态显示为绿色 TEL节点上面P:47.2ms 是一个,这 ...
- JAVA正则表达式高级用法(分组与捕获)
2019独角兽企业重金招聘Python工程师标准>>> 正则表达式在字符串处理中经常使用,关于正则简单的用法相信有一点程序基础的人都懂得一些,这里就不介绍简单基础了.这里主要讲解一下 ...
- GUN sed高级用法,sed脚本编写
这里举一些sed常用的高级用法例子经供参考: 一下操作都针对file.txt文件作修改 [root@QX-××× ~]# cat file.txt libgcc-4.4.7-4.el6.x86_64 ...
- java return用法_Java枚举的高级用法之多键值的映射使用
枚举Enum单映射使用 做Java的各位仁兄姐妹都知道,Java通过HashMap,以及枚举提供了方便的K-V映射功能,例如 枚举单映射使用 但是如果遇到多个键值映射,例如K-K-V的形式怎么办呢?可 ...
- (转)python requests 高级用法 -- 包括SSL 证书错误的解决方案
(转)python requests 高级用法 -- 包括SSL 证书错误的解决方案 参考文章: (1)(转)python requests 高级用法 -- 包括SSL 证书错误的解决方案 (2)ht ...
最新文章
- python定义一个汽车类_汽车类Python程序
- 瞄准医疗数据安全四大风险 东软DBA如何绝地阻击
- Mybatis打印调试sql的两种方式
- 脑机接口成唯一沟通方式,渐冻症晚期父亲终向4岁儿子表达爱意
- 思维题——倒序差分的运用
- c语言 srand time 0,c++ 随机数 srand(time(0)) 用法 | 求索阁
- 移动端真机测试怎么做
- Leetcode--837. 新21点(java)
- Linux移植随笔:对tslib库的ts_test测试程序代码的一点分析
- Python Debug调试技巧
- python sendline,python pexpect sendcontrol关键字符
- 《AutoCAD 2014中文版实用教程》一一2.2 圆类命令
- js记录访问网页的ip_亚马逊新手记录之避免店铺关联
- 碰到的TypeError--记录
- 大数据技术原理与应用学习笔记(九)
- LTE系统中的OFDM技术
- quartz定时任务框架
- md5加密算法使用流程
- linux终端里面的光标很粗,怎么调细
- 感恩节“谢谢”英文怎么说
热门文章
- ISO时间转化时间戳
- HTML引入第三方类库项目需要授权解决方案
- JAVA爬虫Jsoup,抓取房价
- Vue项目中公用footer组件底部位置的适配问题
- Apache引起的wampserver安装好第二次使用无法启动问题
- CNN结构:场景分割与Relation Network
- cachehelper java,初识EHCache缓存框架(2.x版本)
- protobuf版本冲突
- 《计算机科学与工程导论:基于IoT和机器人的可视化编程实践方法第2版》一1.2.2 团队组建...
- 从Javascript单线程谈Event Loop