亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

SpringBoot之RabbitMQ的使用方法

發布時間:2020-08-31 16:11:12 來源:腳本之家 閱讀:178 作者:小崔的筆記本 欄目:編程語言

一 、RabbitMQ的介紹

RabbitMQ是消息中間件的一種,消息中間件即分布式系統中完成消息的發送和接收的基礎軟件,消息中間件的工作過程可以用生產者消費者模型來表示.即,生產者不斷的向消息隊列發送信息,而消費者從消息隊列中消費信息.具體過程如下:

SpringBoot之RabbitMQ的使用方法

從上圖可看出,對于消息隊列來說,生產者、消息隊列、消費者是最重要的三個概念,生產者發消息到消息隊列中去,消費者監聽指定的消息隊列,并且當消息隊列收到消息之后,接收消息隊列傳來的消息,并且給予相應的處理。消息隊列常用于分布式系統之間互相信息的傳遞。

對于RabbitMQ來說,除了這三個基本模塊以外,還添加了一個模塊,即交換機(Exchange)。它使得生產者和消息隊列之間產生了隔離,生產者將消息發送給交換機,而交換機則根據調度策略把相應的消息轉發給對應的消息隊列。

交換機的主要作用是接收相應的消息并且綁定到指定的隊列。交換機有四種類型,分別為Direct、topic、headers、Fanout。

Direct是RabbitMQ默認的交換機模式,也是最簡單的模式。即創建消息隊列的時候,指定一個BindingKey。當發送者發送消息的時候,指定對應的Key。當Key和消息隊列的BindingKey一致的時候,消息將會被發送到該消息隊列中。

topic轉發信息主要是依據通配符,隊列和交換機的綁定主要是依據一種模式(通配符+字符串),而當發送消息的時候,只有指定的Key和該模式相匹配的時候,消息才會被發送到該消息隊列中。

headers也是根據一個規則進行匹配,在消息隊列和交換機綁定的時候會指定一組鍵值對規則,而發送消息的時候也會指定一組鍵值對規則,當兩組鍵值對規則相匹配的時候,消息會被發送到匹配的消息隊列中。

Fanout是路由廣播的形式,將會把消息發給綁定它的全部隊列,即便設置了key,也會被忽略。

二 、SpringBoot整合RabbitMQ(Direct模式)

SpringBoot整合RabbitMQ非常簡單,首先還是pom.xml引入依賴。

 <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-amqp</artifactId>
  </dependency>

在application.properties中配置RabbitMQ相關的信息,并首先啟動了RabbitMQ實例,并創建兩個queue。

SpringBoot之RabbitMQ的使用方法

spring.application.name=spirng-boot-rabbitmq
spring.rabbitmq.host=127.0.0.1
spring.rabbitmq.port=5672
spring.rabbitmq.username=admin
spring.rabbitmq.password=admin

配置Queue(消息隊列),由于采用的是Direct模式,需要在配置Queue的時候指定一個鍵,使其和交換機綁定。

@Configuration
public class RabbitConfig {
  
  @Bean
  public org.springframework.amqp.core.Queue Queue() {

    return new org.springframework.amqp.core.Queue("hello");

  }
}

接著就可以發送消息啦。在SpringBoot中,我們使用AmqpTemplate去發送消息。代碼如下:

@Component
public class HelloSender {
  
  @Autowired
  private AmqpTemplate rabbitTemplate;

  public void send(int index) {

    String context = "hello Queue "+index + new Date();
    System.out.println("Sender : " + context);
    this.rabbitTemplate.convertAndSend("hello", context);
  }
}

生產者發送消息之后就需要消費者接收消息。這里定義了兩個消息消費者,用來模擬生產者與消費者一對多的關系。

@Component
@RabbitListener(queues = "hello")
public class HelloReceiver {
  
  @RabbitHandler
  public void process(String hello) {
    System.out.println("Receiver1 : " + hello);
  }
}
@Component
@RabbitListener(queues = "hello")
public class HelloReceiver2 {
  
  @RabbitHandler
  public void process(String hello) {
    System.out.println("Receiver2 : " + hello);
  }
}

在單元測試中模擬發送消息,批量發送10條消息,兩個接收者分別接收了5條消息。

@Autowired
  private HelloSender helloSender;
  @Test
  public void hello() throws Exception {
    for(int i=0;i<10;i++)
    {
      helloSender.send(i);
    }
  }

SpringBoot之RabbitMQ的使用方法

實際上RabbitMQ還可以支持發送對象,當然由于涉及到序列化和反序列化,該對象要實現Serilizable接口。這里定義了User對象,用來做發送消息內容。

import java.io.Serializable;
public class User implements Serializable{
  
  private String name;
  private String pwd;
  
  public String getPwd() {
    return pwd;
  }
  public void setPwd(String pwd) {
    this.pwd = pwd;
  }
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public User(String name, String pwd) {
    this.name = name;
    this.pwd = pwd;
  }  
  @Override
public String toString() {
    return "User{" +"name='" + name + '\'' +", pwd='" + pwd + '\'' +'}';
  }
}

在生產者中發送User對象。

@Component
public class ModelSender {
  
  @Autowired
  private AmqpTemplate rabbitTemplate;
  
  public void sendModel(User user) {

    System.out.println("Sender object: " + user.toString());
    this.rabbitTemplate.convertAndSend("object", user);

  }
}

在消費者中接收User對象。

@Component
@RabbitListener(queues = "object")
public class ModelRecevicer {
  
  @RabbitHandler
  public void process(User user) {

    System.out.println("Receiver object : " + user);

  }
}

在單元測試中注入ModelSender 對象,實例化User對象,然后發送。

@Autowired
  private ModelSender modelSender;
  @Test
  public void model() throws Exception {
    
    User user=new User("abc","123");    
    modelSender.sendModel(user);
  }

SpringBoot之RabbitMQ的使用方法

三 、SpringBoot整合RabbitMQ(Topic轉發模式)

首先需要在RabbitMQ服務端創建交換機topicExchange,并綁定兩個queue:topic.message、topic.messages。

SpringBoot之RabbitMQ的使用方法

新建TopicRabbitConfig,設置對應的queue與binding。

@Configuration
public class TopicRabbitConfig {
  
  final static String message = "topic.message";
  final static String messages = "topic.messages";
  
  @Bean
  public Queue queueMessage() {
    return new Queue(TopicRabbitConfig.message);
  } 
  
  @Bean
  public Queue queueMessages() {
    return new Queue(TopicRabbitConfig.messages);
  }

  @Bean
  TopicExchange exchange() {
    return new TopicExchange("topicExchange");
  }

  @Bean
  Binding bindingExchangeMessage(Queue queueMessage, TopicExchange exchange) {
    return BindingBuilder.bind(queueMessage).to(exchange).with("topic.message");
  }

  @Bean
  Binding bindingExchangeMessages(Queue queueMessages, TopicExchange exchange) {
    return BindingBuilder.bind(queueMessages).to(exchange).with("topic.#");
  }
}

創建消息生產者,在TopicSender中發送3個消息。

@Component
public class TopicSender {
  
  @Autowired
  private AmqpTemplate rabbitTemplate;

  public void send() {
    String context = "hi, i am message all";
    System.out.println("Sender : " + context);
    this.rabbitTemplate.convertAndSend("topicExchange", "topic.1", context);
  }

  public void send1() {
    String context = "hi, i am message 1";
    System.out.println("Sender : " + context);
    this.rabbitTemplate.convertAndSend("topicExchange", "topic.message", context);
  }

  public void send2() {    
    String context = "hi, i am messages 2";
    System.out.println("Sender : " + context);
    this.rabbitTemplate.convertAndSend("topicExchange", "topic.messages", context);    
  }
}

生產者發送消息,這里創建了兩個接收消息的消費者。

@Component
@RabbitListener(queues = "topic.message")
public class TopicReceiver {
  
  @RabbitHandler
  public void process(String message) {
    System.out.println("Topic Receiver1 : " + message);
  }
}

@Component
@RabbitListener(queues = "topic.messages")
public class TopicReceiver2 {
  
  @RabbitHandler
  public void process(String message) {

    System.out.println("Topic Receiver2 : " + message);

  }
}

在單元測試中注入TopicSender,利用topicSender 發送消息。

@Autowired
  private TopicSender topicSender;
  @Test
  public void topicSender() throws Exception {      
    topicSender.send();    
    topicSender.send1();    
    topicSender.send2();
  }

SpringBoot之RabbitMQ的使用方法

從上面的輸出結果可以看到,Topic Receiver2 匹配到了所有消息,Topic Receiver1只匹配到了1個消息。

四 、SpringBoot整合RabbitMQ(Fanout Exchange形式)

Fanout Exchange形式又叫廣播形式,因此我們發送到路由器的消息會使得綁定到該路由器的每一個Queue接收到消息。首先需要在RabbitMQ服務端創建交換機fanoutExchange,并綁定三個queue:fanout.A、fanout.B、fanout.C。

SpringBoot之RabbitMQ的使用方法

與Topic類似,新建FanoutRabbitConfig,綁定交換機和隊列。

@Configuration
public class FanoutRabbitConfig {
  
  @Bean
  public Queue AMessage() {
    return new Queue("fanout.A");
  }
  
  @Bean
  public Queue BMessage() {
    return new Queue("fanout.B");
  }

  @Bean
  public Queue CMessage() {
    return new Queue("fanout.C");
  }

  @Bean
  FanoutExchange fanoutExchange() {
    return new FanoutExchange("fanoutExchange");
  }

  @Bean
  Binding bindingExchangeA(Queue AMessage,FanoutExchange fanoutExchange) {
    return BindingBuilder.bind(AMessage).to(fanoutExchange);
  }

  @Bean
  Binding bindingExchangeB(Queue BMessage, FanoutExchange fanoutExchange) {
    return BindingBuilder.bind(BMessage).to(fanoutExchange);
  }

  @Bean
  Binding bindingExchangeC(Queue CMessage, FanoutExchange fanoutExchange) {
    return BindingBuilder.bind(CMessage).to(fanoutExchange);
  }
}

創建消息生產者,在FanoutSender中發送消息。

@Component
public class FanoutSender {

  @Autowired
  private AmqpTemplate rabbitTemplate;

  public void send() {
    
    String context = "hi, fanout msg ";
    System.out.println("FanoutSender : " + context);
    this.rabbitTemplate.convertAndSend("fanoutExchange","", context);

  }
}

然后創建了3個接收者FanoutReceiverA、FanoutReceiverB、FanoutReceiverC。

@Component
@RabbitListener(queues = "fanout.A")
public class FanoutReceiverA {
  
  @RabbitHandler
  public void process(String message) {
    System.out.println("fanout Receiver A : " + message);
  }
}
@Component
@RabbitListener(queues = "fanout.B")
public class FanoutReceiverB {
  
  @RabbitHandler
  public void process(String message) {
    System.out.println("fanout Receiver B: " + message);
  }
}
@Component
@RabbitListener(queues = "fanout.C")
public class FanoutReceiverC {
  
  @RabbitHandler
  public void process(String message) {
    System.out.println("fanout Receiver C: " + message);
  }
}

在單元測試中注入消息發送者,發送消息。

 @Autowired
  private FanoutSender fanoutSender;
  @Test
  public void fanoutSender() throws Exception {
    fanoutSender.send();
  }

從下圖可以看到3個隊列都接收到了消息。

SpringBoot之RabbitMQ的使用方法

本章節創建的類比較多,下圖為本章節的結構,也可以直接查看demo源碼了解。

SpringBoot之RabbitMQ的使用方法

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

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

AI

西峡县| 宿松县| 公安县| 饶平县| 丰台区| 鄂托克旗| 尼玛县| 霍城县| 张家口市| 晋中市| 四子王旗| 临西县| 观塘区| 柞水县| 鲁甸县| 鹰潭市| 会泽县| 西和县| 宜春市| 凭祥市| 徐水县| 贵溪市| 金川县| 察隅县| 顺平县| 桦南县| 诏安县| 宁乡县| 紫金县| 洪雅县| 郧西县| 获嘉县| 尉氏县| 荥阳市| 郯城县| 抚州市| 荣成市| 铜鼓县| 泽州县| 吴堡县| 上杭县|