RabbitMQ 实验入门

使用 spring-amqp 实验

发布订阅模型

fanoutExchange 实验

实验步骤:

  1. 编写定义 队列 和 交换机 绑定关系的代码
  2. 创建接口,模拟生产者,方便调试(接受参数 队列名、路由键、[消息])
  3. 定义消费者
    代码示例:
java 复制代码
@Configuration
public class FanoutConfig {
    @Bean
    public FanoutExchange fanoutexchange() {
        //创建广播模式交换机
        return new FanoutExchange("yoj.fanoutexchange");
    }
    // 创建队列
    @Bean
    public Queue fanoutQueue() {
        return new Queue("fanout.queue1");
    }
    // 绑定交换机和队列之间的关系
    @Bean
    public Binding bindingQueue1(Queue fanoutQueue1, FanoutExchange fanoutExchange) {
        return BindingBuilder.bind(fanoutQueue1).to(fanoutExchange);
    }
}
java 复制代码
 @GetMapping("/testMQ/{queueName}/{routingKey}")
    public BaseResponse<String> testMQ(@PathVariable("queueName") String queueName, @PathVariable("routingKey") String routingKey) {
        rabbitTemplate.convertAndSend(queueName, routingKey, "编译执行代码,返回结果");
        return ResultUtils.success("发送成功");
    }

实验效果

发消息

在队列中接受到了消息

direct 案例

  • 定义 关系
java 复制代码
 @RabbitListener(bindings = @QueueBinding(value=@Queue("direct.queue1"), exchange = @Exchange(name="direct.exchange", type = ExchangeTypes.DIRECT), key={"direct.key1"}))
    public void directQueue1Listen(String in) {
        System.out.println("direct.queue1:Received message: " + in);
    }

    @RabbitListener(bindings = @QueueBinding(value=@Queue("direct.queue2"), exchange = @Exchange(name="direct.exchange", type = ExchangeTypes.DIRECT),  key={"direct.key2"}))
    public void directQueue2listen(String in) {
        System.out.println("direct.queue2:Received message: " + in);
    }
相关推荐
虫小宝2 天前
返利app的消息队列架构:基于RabbitMQ的异步通信与解耦实践
分布式·架构·rabbitmq
无缘之缘2 天前
SpringBoot整合RabbitMQ
spring boot·rabbitmq·java-rabbitmq
葵野寺3 天前
【RelayMQ】基于 Java 实现轻量级消息队列(九)
java·开发语言·rabbitmq·java-rabbitmq
Cxzzzzzzzzzz3 天前
RabbitMQ 在实际开发中的应用场景与实现方案
分布式·rabbitmq
优秀的老黄3 天前
Docker部署RabbitMQ
linux·运维·docker·中间件·容器·centos·rabbitmq
java1234_小锋3 天前
RabbitMQ如何实现消息的持久化?
java·rabbitmq·java-rabbitmq
AD钙奶-lalala4 天前
RabbitMQ的核心使用示例
java·rabbitmq·java-rabbitmq
山城码农笑松哥4 天前
国产凝思debian系Linux离线安装rabbitmq教程步骤
linux·debian·rabbitmq
小句4 天前
RabbitMQ对接MQTT消息发布指南
分布式·rabbitmq·ruby
JAVA学习通4 天前
【RabbitMQ】高级特性:持久性·发送方确认·重试机制·TTL·死信队列·延迟队列·事务·消息分发
分布式·rabbitmq