RabbitMQ交换机

1.交换机的作用

(1)接收publisher发送消息

(2)将消息按照规则路由到与之绑定的队列

2.交换机类型

(1)Fanout(广播)

Fanout Exchange会将接受到的消息广播到每一个跟其绑定的queue,所以也叫广播模式

(2)Direct(定向)

Direct Exchange会将接收到的消息根据规则路由到指定的Queue,因此称为定向路由

  • 每一个Queue都与Exchange设置一个BindingKey
  • 发布者发送消息时,指定消息的RoutingKey
  • Exchange将消息路由到BindingKey与消息RoutingKey一直的Queue

(3)Topic(话题)

TopicExchange与DirectExchange类似,区别在于routingKey可以是多个单词的列表,并且以"."号分割,且Queue与Exchange指定BindingKey时可以使用通配符

  • " # ":代指0个或多个单词
  • " * ":代指一个单词

3.声明队列和交换机(一般在消费者中声明)

(1)定义一个配置类,使用SpringAMQP提供了几个类,用来声明队列,交换机及其绑定关系

java 复制代码
import org.springframework.amqp.core.*;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

@Configuration
public class TopicConfiguration {
    //定义一个交换机
    @Bean
    public TopicExchange topicExchange() {
        return ExchangeBuilder.topicExchange("topic_Exchange").build();
    }

    //定义一个消息队列
    @Bean
    public Queue topicQueue() {
        return QueueBuilder.durable("topic_Queue").build();
    }

    //定义绑定关系
    @Bean
    public Binding topicBinding() {
        return BindingBuilder.bind(topicQueue()).to(topicExchange()).with("topic.queue.test");
    }
}

(2)使用SpringAMQP提供的@RabbitListener注解来声明队列和交换机

java 复制代码
import lombok.extern.slf4j.Slf4j;
import org.springframework.amqp.core.ExchangeTypes;
import org.springframework.amqp.rabbit.annotation.Exchange;
import org.springframework.amqp.rabbit.annotation.Queue;
import org.springframework.amqp.rabbit.annotation.QueueBinding;
import org.springframework.stereotype.Component;

@Slf4j
@Component
public class RabbitListener {
    //使用注解定义交换机,消息队列,routingKey值
    @org.springframework.amqp.rabbit.annotation.RabbitListener(bindings = @QueueBinding(
            value = @Queue(name = "topic_Queue",durable = "true"),//设置队列
            exchange = @Exchange(name = "topic_Exchange",type = ExchangeTypes.TOPIC),//设置交换机
            key = {"topic.queue.test"}//设置routingKey值,多个routingKey值以数组的形式定义
            ))
    public void pay(String message) throws InterruptedException {
        System.out.println("支付模块处理的任务:"+message);
    }
相关推荐
白鸽梦游指南几秒前
docker仓库的工作原理及搭建仓库
java·docker·eureka
※DX3906※几秒前
SpringBoot之旅4: MyBatis 操作数据库(进阶) 动态SQL+MyBatis-Plus实战,从入门到熟练,再也不踩绑定异常、SQL拼接坑
java·数据库·spring boot·spring·java-ee·maven·mybatis
java1234_小锋4 分钟前
Java高频面试题:怎么实现Redis的高可用?
java·开发语言·redis
jiankeljx8 分钟前
MySQL-mysql zip安装包配置教程
java
FlagOS智算系统软件栈9 分钟前
智源×Eclipse基金会携手打造PanEval,中欧协同开启“评测+开源+合规”新模式
java·eclipse·开源
日出等日落15 分钟前
用 Kavita实现我的远程数字书屋搭建记!
java·开发语言·ide·vscode·编辑器
Alan GEO实施教练22 分钟前
实用新型专利申请代理机构选择:关键考量因素与实操要点讲解
java·开发语言·python
gelald24 分钟前
JVM - 类加载机制
java·jvm·后端
Darkdreams25 分钟前
Java进阶-在Ubuntu上部署SpringBoot应用
java·spring boot·ubuntu
Roselind_Yi25 分钟前
云计算实验实操|Keystone安装配置+CloudSim仿真平台部署(超详细图文版)
java·经验分享·笔记·ubuntu·云计算·vim·虚拟机