This is the 9th day of my participation in Gwen Challenge

Four switch types

  • Direct

The message is required to be an exact match to a particular routing key

By default, the queue and key match exactly. When using an Exchange of this type, you do not need to specify the name of the routing key. The queue created in this type has a default routing key, which is usually the same as the queue. Refer to canto I

  • Topic matches routing keys to a pattern. At this point the queue needs to be bound to a pattern. The symbol “#” matches one or more words, and the symbol “*” matches no more than one word

    Rabbitmqconfig. Java configuration, created two queues, and switch, binding rules

@Configuration public class RabbitmqConfig { @Bean(name = "message") public Queue queueMessage() { return new Queue("topic.message"); } @Bean(name = "messages") public Queue queueMessages() { return new Queue("topic.messages"); } @Bean public TopicExchange exchange() { return new TopicExchange("exchange"); } @qualifier (@qualifier ("message") Queue queueMessage, TopicExchange exchange) { return BindingBuilder.bind(queueMessage).to(exchange).with("topic.message"); } @Bean Binding bindingExchangeMessages(@Qualifier("messages") Queue queueMessages, TopicExchange exchange) { return BindingBuilder.bind(queueMessages).to(exchange).with("topic.#"); //* denotes one word,# denotes zero or more words}}Copy the code

The producer sender.java binds the switch to the queue

@RestController public class Sender { @Autowired private AmqpTemplate rabbitTemplate; @PostMapping("/send1") public void send1() { String context = "hello " + new Date(); System.out.println("Sender : " + context); this.rabbitTemplate.convertAndSend("exchange","topic.message", context); } @PostMapping("/send2") public void send2() { String context = "world " + new Date(); System.out.println("Sender : " + context); this.rabbitTemplate.convertAndSend("topic.messages", context); }}Copy the code

Consumer Receiver. Java listens to queues,

@rabbitListener (queues="topic.message") public void process1(String STR) {RabbitListener(queues="topic.message") { System.out.println("message:"+str); } @rabbitListener (Queue =" Queue. Messages ") public void process2(String STR) {} @rabbitListener (Queue ="topic. Messages ") {} @rabbitListener (Queue ="topic. System.out.println("messages:"+str); }Copy the code
  • Fanout (Subscription model)

Routing keys are not processed. You simply bind the queue to the switch. A message sent to a switch is forwarded to all queues bound to the switch. RabbitmqConfig. Java configuration

@Configuration public class RabbitmqConfig { @Bean(name="Amessage") public Queue AMessage() { return new Queue("fanout.A"); } @Bean(name="Bmessage") public Queue BMessage() { return new Queue("fanout.B"); } @Bean FanoutExchange fanoutExchange() { return new FanoutExchange("fanoutExchange"); @bean Binding bindingExchangeA(@qualifier ("Amessage") Queue Amessage,FanoutExchange FanoutExchange) {return  BindingBuilder.bind(AMessage).to(fanoutExchange); } @Bean Binding bindingExchangeB(@Qualifier("Bmessage") Queue BMessage, FanoutExchange fanoutExchange) { return BindingBuilder.bind(BMessage).to(fanoutExchange); }}Copy the code

Producers Sender. Java

rabbitTemplate.convertAndSend("fanoutExchange","","xixi");
Copy the code

Consumer Receiver. Java

@Component public class Receiver { @RabbitListener(queues="fanout.A") public void processA(String str1) { System.out.println("ReceiveA:"+str1); } @RabbitListener(queues="fanout.B") public void processB(String str) { System.out.println("ReceiveB:"+str); }}Copy the code
  • Headers (less commonly used) Rabbitmqconfig.java configuration
@Bean public Queue queueN1() { return new Queue("queueN1"); } @Bean public Queue queueN2() { return new Queue("queueN2"); } @Bean public HeadersExchange headersExchange(){ return new HeadersExchange("headersExchange"); } @bean public Binding queueN1Binding(){// All key values match Map<String,Object> Map = new HashMap<>(); map.put("queueName","queueN1"); map.put("bindType","whereAll"); return BindingBuilder.bind(queueN1()).to(headersExchange()).whereAll(map).match(); } @bean public Binding queueN2Binding(){// There are keys matching Map<String,Object> Map = new HashMap<>(); map.put("queueName","queueN2"); map.put("bindType","whereAny"); return BindingBuilder.bind(queueN2()).to(headersExchange()).whereAny(map).match(); }Copy the code

Producers Sender. Java

@Autowired
    private AmqpTemplate rabbitTemplate;
    @PostMapping("/send1")
    public void send1(){
        String messageStr = "hello queueN1";
        MessageProperties messageProperties = new MessageProperties();
        messageProperties.setHeader("queueName","queueN1");
        messageProperties.setHeader("bindType","whereAll");
        Message message = new Message(messageStr.getBytes(), messageProperties);
        rabbitTemplate.send("headersExchange",null,message);
    }
    @PostMapping("/send2")
    public void send2(){

        String messageStr = "hello queueN2";
        MessageProperties messageProperties = new MessageProperties();
        messageProperties.setHeader("queueName","queueN2");
        messageProperties.setHeader("bindType","whereAll");
        Message message = new Message(messageStr.getBytes(), messageProperties);
        rabbitTemplate.send("headersExchange",null,message);
        rabbitTemplate.convertAndSend("headersExchange",messageStr);
    }
Copy the code

Consumer Receiver. Java

@Component public class Receiver { @RabbitListener(queues = "queueN1") public void listerQueueN1(byte[] bytes){ System.out.println("queueN1" + new String(bytes)); } @RabbitListener(queues = "queueN2") public void listerQueueN2(byte[] bytes){ System.out.println("queueN2" + new String(bytes)); }}Copy the code