七、Redis 基础命令---任务队列
来源:互联网 发布:java snmp4j get超时 编辑:程序博客网 时间:2024/06/05 14:11
1、优势:松耦合
易于扩展 ,消费者可以扩展多个,分布在不同的服务器中
2、LPUSH RPOP
3、BRPOP命令和RPOP相似,唯一区别:当列表中没有元素时,BRPOP命令会一直阻塞住链接,知道有新元素加入
4、BRPOP key timeout
timeout 等于0 表示不限制等待时间(单位是秒),如果没有元素会一直阻塞下去。如:BRPOP list 0
5、BRPOP key 1
阻塞1秒,取出数据。返回值是一个数组,第一个元素是键名,第二个元素是 值value。如果没有数据,返回nil
127.0.0.1:6379> BRPOP list 0
1) "list"2) "13"(11.46s)
127.0.0.1:6379> BRPOP list 2(nil)
6、优先级队列 BLPOP queue:1 queue2:2 queue3:3 0
如果都有值,优先取出 queue2队列的值
7、订阅SUBCRIBE channel channelNo .处于订阅状态的客户端只能使用四中命令:SUBSCRIBE/UNSUBSCRIBE/PSUBSCRIBE/PUNSUBSCRIBE
Reading messages... (press Ctrl-C to quit)
1) "subscribe"3) (integer) 1
2) "channel"
可以同时订阅多个消息频道
127.0.0.1:6379> SUBSCRIBE channel1 channel2 channel3
Reading messages... (press Ctrl-C to quit)1) "subscribe"2) "channel1"3) (integer) 11) "subscribe"2) "channel2"3) (integer) 21) "subscribe"
2) "channel3"
3) (integer) 3
8、发布消息PUBLISH channel channelNo message .返回值表示收到此消息的客户端数量
也可以同时取消多个消息频道
127.0.0.1:6379> PUBLISH channel hello
(integer) 1
(integer) 1
9、PSUBSCRIBE channel1.?* 订阅指定规则的消息。支持glob风格的通配符格式
如果A客户端订阅了 psubscribe 1.1 和 psubscribe 1.?* 的消息,
这时B客户端向 channel1.1发布消息,A客户端会收到 2 条消息。
10、PUNSUBSCRIBE * 无法退订 channel.* 规则,而是必须使用PUNSUBSCRIBE channel.*退订
11、管道
客户端和Redis是使用TCP协议链接的。在向Redis发送命令和返回执行结果时,都需要经过网络传输。一去一反称为往返延时。
如果要执行多个命令而不相互依赖返回值,可以使用管道技术。一次性向Redis发送多条命令,即把这组命令一起通过管道命令发出。管道可以减少客户端与Redis的通信次数,达到降低往返延迟的目的。
类似于批处理。
0 0
- 七、Redis 基础命令---任务队列
- 【redis】任务队列
- 深入浅出Redis任务队列
- 使用Redis实现任务队列
- redis(五)redis任务队列
- Linux下Redis+crontab实现任务队列
- Redis研究(十五)—任务队列
- 使用Redis做任务队列(Golang)
- 「Redis学习笔记」任务队列
- Redis数据结构list的任务队列
- Redis基础命令
- redis基础命令(上)
- redis基础命令(下)
- Redis基础命令
- redis 基础命令
- redis基础命令
- redis基础命令
- redis入门基础命令
- [每天一个知识点]6-Java语言-char和code point
- 关于HDU 1713 相遇周期
- 原子操作 vs 非原子操作
- DataReader转DataSet方法
- C++语言的15个晦涩特性
- 七、Redis 基础命令---任务队列
- Position beyond number of declared ordinal parameters. Remember that ordinal parameters are 1-based!
- Nginx、Lighttpd与Apache的区别
- uva1388(数学)
- dp小结
- coco2dx 中常用的宏定义
- android SparseArray替代HashMap的分析
- Codeforces Round #287 (Div. 2) A B C
- git设置ssh key