RabbitMQ整合SpringCloud

这篇博客介绍了如何将RabbitMQ与SpringCloud进行整合。首先从RabbitMQ的基础入门讲起,然后逐步深入到两种不同的消息模式。接着,作者创建了两个工程:rabbitmq-springcloud-consumer(消费者)和rabbitmq-springcloud-producer(生产者),分别实现了接收和发送消息的功能。在每个工程中,详细列出了关键的配置文件和代码。最后,提供了测试代码以验证整合的正确性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

博客目录

传送门

RabbitMQ入门
RabbitMQ消息模式一
RabbitMQ消息模式二

直接开始

创建新工程rabbitmq-common
在这里插入图片描述
common公共包,只需要写共同的部分就可以了
Order

package com.onlyk.rabbitmqcommon.entity;

import java.io.Serializable;

/**
 * @author only老K 我为自己代言
 * @create 2020-03-25 9:42
 * @blogaddress https://blog.youkuaiyun.com/weixin_44255950
 * 支付完毕后下单操作...
 */
public class Order implements Serializable {
   
    private String id;
    private String name;

    public Order(String id, String name) {
   
        this.id = id;
        this.name = name;
    }

    public Order() {
   
    }

    public String getId() {
   
        return id;
    }

    public void setId(String id) {
   
        this.id = id;
    }

    public String getName() {
   
        return name;
    }

    public void setName(String name) {
   
        this.name = name;
    }
}

新建rabbitmq-springcloud-consumer
RabbitReceiver

package com.onlyk.rabbitmqspringcloudconsumer.conusmer;

import com.onlyk.rabbitmqcommon.entity.Order;
import com.rabbitmq.client.Channel;
import org.springframework.amqp.rabbit.annotation.*;
import org.springframework.amqp.support.AmqpHeaders;
import org.springframework.messaging.Message;
import org.springframework.messaging.handler.annotation.Headers;
import org.springframework.messaging.handler.annotation.Payload;
import org.springframework.stereotype.Component;

import java.util.Map;

/**
 * @author only老K 我为自己代言
 * @create 2020-03-25 9:54
 * @blogaddress https://blog.youkuaiyun.com/weixin_44255950
 */
@Component
public class RabbitReceiver {
   
    /**
     * 上面这种是将队列,交换机。以及他们之间的关系声明在代码中
     * @param message
     * @param channel
     * @throws Exception
     */
    @RabbitListener(bindings = @QueueBinding(
            value = @Queue(value = "queue-1",
                    durable="true"),
            exchange = @Exchange(value = "exchange-1",
                    durable="true",
                    type= "topic",
                    ignoreDeclarationExceptions = "true"),
            key = "springboot.*"
    )
    )
    @RabbitHandler
    public void onMessage(Message message, Channel channel) throws Exception {
   
        System.err.println("--------------------------------------");
        System.err.println("消费端Payload: " + message.getPayload());
        Long deliveryTag = (Long)message.getHeaders().get(AmqpHeaders.DELIVERY_TAG);
        //手工ACK
        channel.basicAck(deliveryTag, false);
    }


    /**
     *
     *   下面这种是将队列,交换机。以及他们之间的关系声明在全局配置文件中
     *     spring.rabbitmq.listener.order.queue.name=queue-2
     spring.rabbitmq.listener.order.queue.durable=true
     spring.rabbitmq.listener.order.exchange.name=exchange-1
     spring.rabbitmq.listener.order.exchange.durable=true
     spring.rabbitmq.listener.order.exchange.type=topic
     spring.rabbitmq.listener.order.exchange.ignoreDeclarationExceptions=true
     spring.rabbitmq.listener.order.key=springboot.*
     * @param order
     * @param channel
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值