中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

rabbitMQ的發布模式怎么實現

發布時間:2022-09-27 16:22:04 來源:億速云 閱讀:77 作者:iii 欄目:開發技術

這篇“rabbitMQ的發布模式怎么實現”文章的知識點大部分人都不太理解,所以小編給大家總結了以下內容,內容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“rabbitMQ的發布模式怎么實現”文章吧。

Springboot rabbit MQ 發布/訂閱模式

生產者聲明兩個隊列和一個扇出交換機,并將兩個隊列綁定到交換機

開關有四種類型:fanout、direct、topic和header(文末有介紹)

導入 com.example.rabbitmq.constant.RabbitConstant;
導入 org.springframework.amqp.core.*;
導入 org.springframework.context.annotation.Bean;
導入 org.springframework.context.annotation.Configuration;@Configuration公共類 RabbitPublishSubscribeProvider { 
    @Bean
    公共隊列 pubsubQueueFirst() { 
        return new Queue(RabbitConstant.PUBLISH_SUBSCRIBE_FIRST_QUEUE_NAME); 
    } 
    @Bean
    公共隊列 pubsubQueueSecond() { 
        return new Queue(RabbitConstant.PUBLISH_SUBSCRIBE_SECOND_QUEUE_NAME); 
    } 
    @Bean
    公共 FanoutExchange fanoutExchange() {        // 創建扇出類型開關,表示交換機會向所有綁定隊列發送消息
        return new FanoutExchange(RabbitConstant.PUBLISH_SUBSCRIBE_EXCHANGE_NAME); 
    } 
    @Bean 
    public Binding pubsubQueueFirstBindFanoutExchange() { 
        // 隊列綁定開關
        return BindingBuilder.bind(pubsubQueueFirst()).to(fanoutExchange()); 
    } 
    @Bean 
    public Binding pubsubQueueSecondBindFanoutExchange() { 
        // 隊列二綁定開關
        return BindingBuilder.bind(pubsubQueueSecond()).to(fanoutExchange()); 
    } 
}

消費者監聽隊列并消費

導入 com.example.rabbitmq.constant.RabbitConstant;
導入 org.springframework.amqp.rabbit.annotation.RabbitHandler;
導入 org.springframework.amqp.rabbit.annotation.RabbitListener;
導入 org.springframework.stereotype.Component;
@Component public class RabbitPublishSubscribeConsumer { 
    @RabbitListener(queues = RabbitConstant.PUBLISH_SUBSCRIBE_FIRST_QUEUE_NAME) 
    @RabbitHandler 
    public void pubsubQueueFirst(String context) { 
        System.out.println("rabbit pubsub queue first receiver:" + context); 
    } 
    @RabbitListener(queues = RabbitConstant.PUBLISH_SUBSCRIBE_SECOND_QUEUE_NAME) 
    @RabbitHandler 
    public void pubsubQueueSecond(String context) {        System.out.println("rabbit pubsub 隊列第二個接收者:" + context); 
    } 
}

單元測試

@Test public void pubsub() { 
    rabbitTemplate.convertAndSend(RabbitConstant.PUBLISH_SUBSCRIBE_EXCHANGE_NAME, null, "發布/訂閱你好"); 
}

響應結果

以上就是關于“rabbitMQ的發布模式怎么實現”這篇文章的內容,相信大家都有了一定的了解,希望小編分享的內容對大家有幫助,若想了解更多相關的知識內容,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

夹江县| 昌江| 富川| 盱眙县| 凉山| 莱州市| 望城县| 锦屏县| 中卫市| 柯坪县| 双流县| 鹤壁市| 农安县| 萨嘎县| 盘山县| 合阳县| 双辽市| 大冶市| 三穗县| 乌拉特中旗| 宁远县| 遂宁市| 伊通| 松桃| 广西| 海盐县| 江陵县| 彝良县| 峨眉山市| 都匀市| 会理县| 塔河县| 额济纳旗| 六盘水市| 桃源县| 普兰店市| 资讯| 鄂托克旗| 曲松县| 汉川市| 长子县|