色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

RabbitMQ中的發(fā)布訂閱模型

科技綠洲 ? 來源:Java技術(shù)指北 ? 作者:Java技術(shù)指北 ? 2023-09-25 14:30 ? 次閱讀

上一篇文章中,簡(jiǎn)單的介紹了一下RabbitMQ的work模型。這篇文章來學(xué)習(xí)一下RabbitMQ中的發(fā)布訂閱模型。

發(fā)布訂閱模型(Publish/Subscribe):簡(jiǎn)單的說就是隊(duì)列里面的消息會(huì)被多個(gè)消費(fèi)者同時(shí)接受到,消費(fèi)者接收到的信息一致。

發(fā)布訂閱模型適合于做模塊之間的異步通信

圖片
img

適用場(chǎng)景

  1. 發(fā)送并記錄日志信息
  2. springcloud的config組件里面通知配置自動(dòng)更新
  3. 緩存同步
  4. 微信訂閱號(hào)

演示

生產(chǎn)者

public class Producer {
    private static final String EXCHANGE_NAME = "exchange_publish_1";

    public static void main(String[] args) throws IOException, TimeoutException {
        Connection connection = ConnectionUtils.getConnection();
        Channel channel = connection.createChannel();
        // 聲明交換機(jī)
        channel.exchangeDeclare(EXCHANGE_NAME, "fanout");
        // 發(fā)送消息到交換機(jī)
        for (int i = 0; i < 100; i++) {
            channel.basicPublish(EXCHANGE_NAME, "", null, ("發(fā)布訂閱模型的第 " + i + " 條消息").getBytes());
        }
        // 關(guān)閉資源
        channel.close();
        connection.close();
    }
}

消費(fèi)者

// 消費(fèi)者1
public class Consumer {
    private static final String QUEUE_NAME = "queue_publish_1";
    private static final String EXCHANGE_NAME = "exchange_publish_1";

    public static void main(String[] args) throws IOException, TimeoutException {
        Connection connection = ConnectionUtils.getConnection();
        Channel channel = connection.createChannel();
        // 聲明隊(duì)列
        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        // 聲明交換機(jī)
        channel.exchangeDeclare(EXCHANGE_NAME, "fanout");
        // 將隊(duì)列綁定到交換機(jī)
        channel.queueBind(QUEUE_NAME, EXCHANGE_NAME, "");
        DefaultConsumer defaultConsumer = new DefaultConsumer(channel) {
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
                System.out.println("隊(duì)列1接收到的消息是:" + new String(body));
            }
        };
        channel.basicConsume(QUEUE_NAME, true, defaultConsumer);
    }
}
// 消費(fèi)者2
public class Consumer2 {
    private static final String QUEUE_NAME = "queue_publish_2";
    private static final String EXCHANGE_NAME = "exchange_publish_1";

    public static void main(String[] args) throws IOException, TimeoutException {
        Connection connection = ConnectionUtils.getConnection();
        Channel channel = connection.createChannel();
        // 聲明隊(duì)列
        channel.queueDeclare(QUEUE_NAME, false, false, false, null);
        // 聲明交換機(jī)
        channel.exchangeDeclare(EXCHANGE_NAME, "fanout");
        // 將隊(duì)列綁定到交換機(jī)
        channel.queueBind(QUEUE_NAME, EXCHANGE_NAME, "");
        DefaultConsumer defaultConsumer = new DefaultConsumer(channel) {
            @Override
            public void handleDelivery(String consumerTag, Envelope envelope, AMQP.BasicProperties properties, byte[] body) throws IOException {
                System.out.println("隊(duì)列2接收到的消息是:" + new String(body));
            }
        };
        channel.basicConsume(QUEUE_NAME, true, defaultConsumer);
    }
}

測(cè)試

先啟動(dòng)2個(gè)消費(fèi)者,再啟動(dòng)生產(chǎn)者

圖片

圖片

可以看出來消費(fèi)者1和消費(fèi)者2接收到的消息是一模一樣的 ,每個(gè)消費(fèi)者都收到了生產(chǎn)者發(fā)送的消息;

發(fā)布訂閱模型,用到了一個(gè)新的東西-交換機(jī),這里也解釋一下相關(guān)方法的參數(shù)

// 聲明交換機(jī)
channel.exchangeDeclare(EXCHANGE_NAME, "fanout");

// 該方法的最多參數(shù)的重載方法是:
Exchange.DeclareOk exchangeDeclare(String exchange,
                                    BuiltinExchangeType type,
                                    boolean durable,
                                    boolean autoDelete,
                                    boolean internal,
                                    Map< String, Object > arguments) throws IOException;

/**
 *  param1:exchange,交換機(jī)名稱
 *  param2:type,交換機(jī)類型;直接寫 string效果一致;內(nèi)置了4種交換機(jī)類型:
 *   direct(路由模式)、fanout(發(fā)布訂閱模式)、
 *   topic(topic模式-模糊匹配)、headers(標(biāo)頭交換,由Headers的參數(shù)分配,不常用)
 *  param3:durable,是否持久化交換機(jī)   false:默認(rèn)值,不持久化
 *  param4:autoDelete,沒有消費(fèi)者使用時(shí),是否自動(dòng)刪除交換機(jī)   false:默認(rèn)值,不刪除
 *  param5:internal,是否內(nèi)置,如果設(shè)置 為true,則表示是內(nèi)置的交換器, 客戶端程序無法直接發(fā)送消息到這個(gè)交換器中, 只能通過交換器路由到交換器的方式  false:默認(rèn)值,允許外部直接訪問
 *  param6:arguments,交換機(jī)的一些其他屬性,默認(rèn)值為 null
 */
// 將隊(duì)列綁定到交換機(jī)
channel.queueBind(QUEUE_NAME, EXCHANGE_NAME, "");
/**
 *  param1:destination,目的地,隊(duì)列的名字
 *  param2:source,資源,交換機(jī)的名字
 *  param3:routingKey,路由鍵(目前沒有用到routingKey,填 "" 即可)
 */

小結(jié)

本文到這里就結(jié)束了,介紹了RabbitMQ通信模型中的發(fā)布訂閱模型,適合于做模塊之間的異步通信。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 交換機(jī)
    +關(guān)注

    關(guān)注

    21

    文章

    2656

    瀏覽量

    99978
  • 緩存
    +關(guān)注

    關(guān)注

    1

    文章

    240

    瀏覽量

    26724
  • 模型
    +關(guān)注

    關(guān)注

    1

    文章

    3296

    瀏覽量

    49042
  • springcloud
    +關(guān)注

    關(guān)注

    0

    文章

    17

    瀏覽量

    1542
  • rabbitmq
    +關(guān)注

    關(guān)注

    0

    文章

    18

    瀏覽量

    1037
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    RabbitMQ通信模型的work模型

    上一篇文章,簡(jiǎn)單的介紹了一下RabbitMQ,以及安裝和hello world。 有的小伙伴留言說看不懂其中的方法參數(shù),這里先解釋一下幾個(gè)基本的方法參數(shù)。 // 聲明隊(duì)列方法
    的頭像 發(fā)表于 09-25 14:34 ?537次閱讀
    <b class='flag-5'>RabbitMQ</b>通信<b class='flag-5'>模型</b><b class='flag-5'>中</b>的work<b class='flag-5'>模型</b>

    RabbitMQ是什么

    在工作中經(jīng)常會(huì)用到消息隊(duì)列處理各種問題,今天指北君帶領(lǐng)大家來學(xué)一個(gè)很常用到的技術(shù)-RabbitMQ;接下來還會(huì)有關(guān)于RabbitMQ的系列教程,對(duì)你有幫助的話記得關(guān)注哦~ RabbitMQ
    的頭像 發(fā)表于 09-25 14:36 ?892次閱讀
    <b class='flag-5'>RabbitMQ</b>是什么

    MQTT協(xié)議介紹之一:發(fā)布/訂閱

    ,MQTT被正式批準(zhǔn)為OASIS標(biāo)準(zhǔn)。 MQTT 3.1.1現(xiàn)在是該協(xié)議的最新版本。發(fā)布/訂閱模式發(fā)布/訂閱模式(pub / sub)是傳統(tǒng)客戶端 - 服務(wù)器
    發(fā)表于 08-25 19:58

    Redis的發(fā)布訂閱機(jī)制

    Redis之發(fā)布訂閱機(jī)制
    發(fā)表于 06-11 13:21

    MQTT的通信模型及消息

     MQTT通信模型    MQTT協(xié)議是基于客戶端-服務(wù)器模型,在協(xié)議主要有三種身份:發(fā)布者(Publisher)、服務(wù)器(Broker) 以及
    發(fā)表于 01-19 15:57

    NodeMCU實(shí)現(xiàn)訂閱發(fā)布主題

    NodeMCU實(shí)現(xiàn)訂閱發(fā)布主題。1、要點(diǎn)掃盲1.1 MQTT《MQTT協(xié)議--MQTT協(xié)議簡(jiǎn)介及原理》《MQTT協(xié)議--MQTT協(xié)議解析》1.2 OneNET《NodeMCU學(xué)習(xí)(十)--發(fā)送數(shù)據(jù)
    發(fā)表于 11-01 08:37

    請(qǐng)問esp32c3,ble mesh怎么向訂閱的分組發(fā)布消息?

    發(fā)布消息,為什么vnd_models模型不可以.有沒有更加簡(jiǎn)單的api,直接傳訂閱分組地址就可以發(fā)布消息的?
    發(fā)表于 02-13 06:47

    請(qǐng)問esp32c3 ble mesh怎么向訂閱的分組發(fā)布消息?

    發(fā)布消息,為什么vnd_models模型不可以.有沒有更加簡(jiǎn)單的api,直接傳訂閱分組地址就可以發(fā)布消息的?
    發(fā)表于 03-06 08:36

    基于SOA的發(fā)布/訂閱系統(tǒng)設(shè)計(jì)

    企業(yè)電子商務(wù)的迅猛發(fā)展已經(jīng)改變了分布式系統(tǒng)的規(guī)模,傳統(tǒng)的基于請(qǐng)求/應(yīng)答的點(diǎn)對(duì) 點(diǎn)、同步通信已不能滿足大規(guī)模動(dòng)態(tài)分布式應(yīng)用環(huán)境。基于SOA 的發(fā)布/訂閱系統(tǒng)模型
    發(fā)表于 07-08 08:42 ?21次下載

    RabbitMQ-CN RabbitMQ中文文檔

    RabbitMQ_into_Chinese.zip
    發(fā)表于 04-19 10:51 ?0次下載
    <b class='flag-5'>RabbitMQ</b>-CN <b class='flag-5'>RabbitMQ</b>中文文檔

    rabbitmq是什么?rabbitmq安裝、原理、部署

    rabbitmq是什么? MQ的全稱是Messagee Queue,因?yàn)橄⒌年?duì)列是隊(duì)列,所以遵循FIFO 先進(jìn)先出的原則是上下游傳遞信息的跨過程通信機(jī)制。 RabbitMQ是一套開源(MPL
    的頭像 發(fā)表于 07-19 13:50 ?1067次閱讀

    RocketMQ和RabbitMQ的區(qū)別

    RocketMQ和RabbitMQ的區(qū)別: 架構(gòu)設(shè)計(jì):RocketMQ是基于主題(Topic)的發(fā)布/訂閱模式,而RabbitMQ則是基于隊(duì)列(Queue)的消息代理系統(tǒng)。 語言支持
    的頭像 發(fā)表于 07-24 13:39 ?1.4w次閱讀

    Topic 模型的使用

    RabbitMQ 是一個(gè)流行的開源消息隊(duì)列軟件,它提供了多種通信模型,例如發(fā)布/訂閱模型、路由模型
    的頭像 發(fā)表于 09-25 11:30 ?698次閱讀

    RabbitMQ的路由模型(direct)

    路由模型 RabbitMQ 提供了五種不同的通信模型,上一篇文章,簡(jiǎn)單的介紹了一下RabbitMQ發(fā)
    的頭像 發(fā)表于 09-25 11:32 ?525次閱讀

    redis和rabbitMQ的區(qū)別

    Redis和RabbitMQ之間的區(qū)別。 架構(gòu)設(shè)計(jì): Redis是一個(gè)內(nèi)存存儲(chǔ)系統(tǒng),它將數(shù)據(jù)存儲(chǔ)在內(nèi)存,以提供快速的讀寫訪問。因此,Redis的存儲(chǔ)能力受到內(nèi)存大小的限制。它使用發(fā)布/訂閱
    的頭像 發(fā)表于 12-04 14:48 ?1489次閱讀
    主站蜘蛛池模板: 俄罗斯搜索引擎Yandex推广入口| 俄罗斯大白屁股| 日韩午夜欧美精品一二三四区| 抽插H浊水H嫩B父皇| 亚洲黄色高清| 久久亚洲人成网站| jizz中国女人| 亚洲2017久无码| 美国一级黄色| 国产成人在线视频| 在线伦理电影网| 日日啪在线影院百度| 九九热视频这里只有精| 百性阁论坛首页| 亚洲精品网址| 色噜噜狠狠色综合中文字幕| 妻子+免费观看完整| 黄色精品视频| 被窝国产理论一二三影院| 医生含着我的奶边摸边做| 色AV色婷婷96人妻久久久| 2023极品少妇XXXO露脸| 乳交高H糙汉宠文| 日本性hd| 美女被触手注入精子强制受孕漫画| 久久精品亚洲| 国产香蕉尹人视频在线| JK白丝校花爽到娇喘视频| 亚洲AV人无码综合在线观看蜜桃| 天堂岛www天堂资源在线| 成人无码国产AV免费看 | 2022国产91精品久久久久久| 2012中文字幕在线动漫电影| 丝袜美女自摸| 日本 一二三 不卡 免费| 久啪久久全部视频在线| 国厂精品114福利电影| 吃寂寞寡妇的奶| 国产精品999| 动漫在线观看免费肉肉| 国产高清视频a在线大全|