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);
    }
相关推荐
泉城老铁14 小时前
Spring Boot深度整合RabbitMQ:从入门到企业级实战
java·后端·rabbitmq
西岭千秋雪_2 天前
RabbitMQ队列的选择
笔记·分布式·学习·rabbitmq·ruby
Bug退退退1233 天前
RabbitMQ 之消息积压
分布式·rabbitmq
Bug退退退1234 天前
RabbitMQ 高级特性之事务
java·分布式·spring·rabbitmq
咖啡啡不加糖4 天前
RabbitMQ 消息队列:从入门到Spring Boot实战
java·spring boot·rabbitmq
Bug退退退1235 天前
RabbitMQ 幂等性
分布式·rabbitmq
Bug退退退1235 天前
RabbitMQ 高级特性之延迟队列
java·spring·rabbitmq·java-rabbitmq
蹦跑的蜗牛5 天前
Spring Boot 整合 RabbitMQ
spring boot·rabbitmq
qq_529835355 天前
RabbitMQ的消息可靠传输
分布式·rabbitmq
gtestcandle6 天前
rabbitmq 的多用户、多vhost使用
分布式·rabbitmq