七、Redis 基础命令---任务队列

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"
2) "channel"
        3) (integer) 1
     可以同时订阅多个消息频道
127.0.0.1:6379> SUBSCRIBE channel1 channel2 channel3
Reading messages... (press Ctrl-C to quit)
1) "subscribe"
2) "channel1"
3) (integer) 1
1) "subscribe"
2) "channel2"
3) (integer) 2
1) "subscribe"
          2) "channel3"
3) (integer) 3

8、发布消息PUBLISH channel channelNo message .返回值表示收到此消息的客户端数量
          也可以同时取消多个消息频道
          127.0.0.1:6379> PUBLISH channel hello
               (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的通信次数,达到降低往返延迟的目的。
        类似于批处理。




     
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值