• Redis的频道发布与消息订阅


    Redis的频道发布与消息订阅

    官网介绍

    进程间的一种通信模式:发送者(pub)发送消息,订阅者(sub)接收消息。

    订阅/发布消息图

    下图展示了频道channel1,以及订阅这个频道的三个客户端-client2client5client1

     

    当有新消息通过PUBLISH命令发送给频道channel1时,这个消息就会被发送给订阅它的三个客户端。

     

    Redis 发布订阅命令

    PSUBSCRIBE pattern [pattern ...]

    订阅一个或者多个符合模式匹配的频道

    【假设客户端同时订阅了某种模式和符合该模式的某个频道,那么发送给这个频道的消息将被客户端接收到两次,只不过这两条消息的类型不同,一个是message类型,一个是pmessage类型,但其内容相同。 】

    PUBSUB subcommand [argument [argument ...]]

    返回由活跃频道组成的列表,即可以查询订阅与发布系统的状态

    PUBLISH channel message 

    发送消息到指定的频道

    【其返回值为接收到该消息的订阅者的数量】

    SUBSCRIBE channel [channel ...] 

    订阅一个或多个频道

    【其返回值包括客户端订阅的频道,目前已订阅的频道数量,以及接收到的消息,其中subscribe表示已经成功订阅了某个频道】

    PUNSUBSCRIBE [pattern [pattern ...]] 

    退订所有符合模式匹配的频道

    UNSUBSCRIBE [channel [channel ...]] 

    退订一个或多个频道

    【Redis采用UNSUBSCRIBE和PUNSUBSCRIBE命令取消订阅,其返回值与订阅类似。 
    由于Redis的订阅操作是阻塞式的,因此一旦客户端订阅了某个频道或模式,就将会一直处于订阅状态直到退出。

    在SUBSCRIBE,PSUBSCRIBE,UNSUBSCRIBE和PUNSUBSCRIBE命令中,

    其返回值都包含了该客户端当前订阅的频道和模式的数量,当这个数量变为0时,该客户端会自动退出订阅状态。】

     简单练习

    客户端先订阅后,消息发布后才能接收到消息

    1. 可以一次性订阅多个,SUBSCRIBE c1 c2 c3
    2. 消息发布,PUBLISH c2 hell0-redis
    3. 订阅多个,通配符*PSUBSCRIBE new*
    4. 收取消息,PUBLISH new1 redis2019
  • 相关阅读:
    golang 使用 iota
    Event Sourcing Pattern 事件源模式
    Win10桌面预览版14316更新内容大全
    腾信微信公众号初步开发应用
    微信支付:H5吊起支付API,不显示“确认支付、输入密码”界面
    开发者了解---微信公众号(服务号、订阅号、企业号)的区别
    X240 Win10企业版 14279版本 电池标尺白底问题
    Go项目的目录结构
    Command and Query Responsibility Segregation (CQRS) Pattern 命令和查询职责分离(CQRS)模式
    .NET环境下基于RBAC的访问控制
  • 原文地址:https://www.cnblogs.com/-wenli/p/10934549.html
Copyright © 2020-2023  润新知