91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

阿鲁科尔沁旗| 潼关县| 岳池县| 蓬莱市| 成都市| 水富县| 太白县| 八宿县| 灵丘县| 朝阳县| 阿城市| 山西省| 神池县| 永泰县| 八宿县| 鄂托克旗| 柳林县| 定西市| 长汀县| 四会市| 彰武县| 上思县| 民县| 新宁县| 济源市| 应城市| 高青县| 绥芬河市| 大冶市| 余姚市| 汾阳市| 房产| 泽库县| 团风县| 曲周县| 丹寨县| 金堂县| 河北省| 长沙县| 昌江| 连云港市|