spring boot操作rabbitmq的发布订阅队列示例

 

项目基础结构参考:

spring boot操作rabbitmq的简单队列示例

生产者(发布者)源码:https://gitee.com/constfafa/rabbitmq-producer-pub-sub-queue

消费者1源码:https://gitee.com/constfafa/rabbitmq-consumer-pub-sub-queue01

消费者2源码:https://gitee.com/constfafa/rabbitmq-consumer-pub-sub-queue02

工作过程:

生产者每个1秒将消息发送给rabbitmq的fanout类型的Exchange上,fanout不处理路由routingkey,只要与之绑定的队列都能收到消息。

两个消费者声明不同的队列队列,并绑定到Exchange上

注意:exchanger没有存储消息的能力,只有队列有存储消息的能力。所以在测试的时候,要先将两个consumer启动起来,之后再启动producer。

Rabbitmq的效果:

结果:

生产者

消费者1:

 

消费者2:

 

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是 Spring Boot 整合 RabbitMQ 的详细示例: 1. 引入依赖 在 pom.xml 文件中引入以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` 2. 配置 RabbitMQ 在 application.properties 文件中配置 RabbitMQ: ```properties spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest ``` 3. 创建生产者 创建一个生产者(Producer)类,用于发送消息到 RabbitMQ: ```java @Component public class Producer { @Autowired private RabbitTemplate rabbitTemplate; public void send(String message) { rabbitTemplate.convertAndSend("myExchange", "myRoutingKey", message); } } ``` 4. 创建消费者 创建一个消费者(Consumer)类,用于从 RabbitMQ 接收消息: ```java @Component public class Consumer { @RabbitListener(queues = "myQueue") public void receive(String message) { System.out.println("Received message: " + message); } } ``` 5. 创建队列、交换机、绑定关系 使用 RabbitAdmin 类创建队列、交换机、绑定关系: ```java @Configuration public class RabbitConfig { @Autowired private RabbitTemplate rabbitTemplate; @PostConstruct public void setup() { RabbitAdmin rabbitAdmin = new RabbitAdmin(rabbitTemplate.getConnectionFactory()); Queue queue = new Queue("myQueue", true); DirectExchange exchange = new DirectExchange("myExchange", true, false); rabbitAdmin.declareQueue(queue); rabbitAdmin.declareExchange(exchange); rabbitAdmin.declareBinding(BindingBuilder.bind(queue).to(exchange).with("myRoutingKey")); } } ``` 6. 测试 在控制器(Controller)中调用生产者发送消息,测试消费者是否成功接收消息: ```java @RestController public class TestController { @Autowired private Producer producer; @GetMapping("/test") public String test() { producer.send("Hello, RabbitMQ!"); return "Message sent."; } } ``` 以上就是 Spring Boot 整合 RabbitMQ 的详细示例,希望能对你有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值