• redis(五)


    发布订阅

    • 发布者不是计划发送消息给特定的接收者(订阅者),而是发布的消息分到不同的频道,不需要知道什么样的订阅者订阅
    • 订阅者对一个或多个频道感兴趣,只需接收感兴趣的消息,不需要知道什么样的发布者发布的
    • 发布者和订阅者的解耦合可以带来更大的扩展性和更加动态的网络拓扑
    • 客户端发到频道的消息,将会被推送到所有订阅此频道的客户端
    • 客户端不需要主动去获取消息,只需要订阅频道,这个频道的内容就会被推送过来

    消息的格式

    • 推送消息的格式包含三部分
    • part1:消息类型,包含三种类型
      • subscribe,表示订阅成功
      • unsubscribe,表示取消订阅成功
      • message,表示其它终端发布消息
    • 如果第一部分的值为subscribe,则第二部分是频道,第三部分是现在订阅的频道的数量
    • 如果第一部分的值为unsubscribe,则第二部分是频道,第三部分是现在订阅的频道的数量,如果为0则表示当前没有订阅任何频道,当在Pub/Sub以外状态,客户端可以发出任何redis命令
    • 如果第一部分的值为message,则第二部分是来源频道的名称,第三部分是消息的内容

    命令

    • 订阅
    SUBSCRIBE 频道名称 [频道名称 ...]
    
    • 取消订阅
    • 如果不写参数,表示取消所有订阅
    UNSUBSCRIBE 频道名称 [频道名称 ...]
    
    • 发布
    PUBLISH 频道 消息

    主从配置

    • 一个master可以拥有多个slave,一个slave又可以拥有多个slave,如此下去,形成了强大的多级服务器集群架构
    • 比如,将ip为192.168.1.10的机器作为主服务器,将ip为192.168.1.11的机器作为从服务器
    • 设置主服务器的配置
    bind 192.168.1.10
    
    • 设置从服务器的配置
    • 注意:在slaveof后面写主机ip,再写端口,而且端口必须写
    bind 192.168.1.11
    slaveof 192.168.1.10 6379
    
    • 在master和slave分别执行info命令,查看输出信息
    • 在master上写数据
    set hello world
    
    • 在slave上读数据
    get hello
     
  • 相关阅读:
    kafka topic消息分配partition规则(Java源码)
    mycat快速搭建入门
    CountDownLatch、CyclicBarrier和Semaphore使用
    jinfo Java配置信息工具
    jstat虚拟机统计信息监视工具
    jps虚拟机进程状态工具
    webpack2教程--从入门到放弃
    简单的add函数的N种写法
    从零开始写个一个豆瓣电影 (小程序教程3)
    从零开始写个一个豆瓣电影 (小程序教程2)”
  • 原文地址:https://www.cnblogs.com/leecoffee/p/9039222.html
Copyright © 2020-2023  润新知