Spring整合RabbitMQ

Spring整合RabbitMQ

1.生产者Spring-Producer

1.1 创建生产者工程

整合用到的maven坐标,主要有:spring-context(Spring核心)spring-test(测试)junitspring-rabbit(官方整合方案)

<dependencies>
    <!-- https://mvnrepository.com/artifact/org.springframework/spring-context -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.springframework/spring-test -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>5.1.7.RELEASE</version>
        <scope>test</scope>
    </dependency>
    <!-- https://mvnrepository.com/artifact/junit/junit -->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
        <scope>test</scope>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.springframework.amqp/spring-rabbit -->
    <dependency>
        <groupId>org.springframework.amqp</groupId>
        <artifactId>spring-rabbit</artifactId>
        <version>2.1.8.RELEASE</version>
    </dependency>
</dependencies>

1.2 创建RabbitMQ配置文件

这里我们创建的是一个RabbitMQ配置文件,名称为rabbitmq.properties。目的是方便将配置文件中的信息加载到Spring中,就无需在xml文件中修改了。

# RabbitMQ地址
rabbitmq.host=192.168.52.128
# RabbitMQ端口
rabbitmq.port=5672
# 用户名
rabbitmq.username=admin
# 密码
rabbitmq.password=admin
# 虚拟机
rabbitmq.virtual-host=/test

1.3 创建整合配置文件

RabbitMQ和Spring使用xml文件进行整合,意味着大部分的配置类或模板都在xml文件中,我们默认的文件名为:spring-rabbitmq-producer.xml

xml文件用到的默认约束

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:rabbit="http://www.springframework.org/schema/rabbit"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/context
       https://www.springframework.org/schema/context/spring-context.xsd
       http://www.springframework.org/schema/rabbit
       http://www.springframework.org/schema/rabbit/spring-rabbit.xsd">
</beans>

(1)加载配置文件,并创建连接工程connectionFactory

在这里我们需要注意的是加载配置文件的路径,classpath:rabbitmq.properties

<!--加载配置文件-->
<context:property-placeholder location="classpath:rabbitmq.properties"/>

<!-- 定义rabbitmq connectionFactory -->
<rabbit:connection-factory id="connectionFactory"
                           host="${rabbitmq.host}"
                           port="${rabbitmq.port}"
                           username="${rabbitmq.username}"
                           password="${rabbitmq.password}"
                           virtual-host="${rabbitmq.virtual-host}"/>

(2)定义管理交换机、队列

<!--定义管理交换机、队列-->
<rabbit:admin connection-factory="connectionFactory"/>

(3)定义普通队列

<rabbit:queue id="spring_queue" name="spring_queue" auto-declare="true"/>

不绑定到交换机则绑定到默认交换机,默认交换机类型为direct,名字为:“”,路由键为队列的名称。

  • id:表示bean的id
  • name:表示队列的名称
  • auto-declare:如果没有是否自动创建
  • auto-delete:是否自动删除队列(当最后一个消费者断开连接时)

(4)定义广播类型交换机

<!--定义广播交换机中的持久化队列spring_fanout_queue_1,不存在则自动创建-->
<rabbit:queue id="spring_fanout_queue_1" name="spring_fanout_queue_1" auto-declare="true"/>

<!--定义广播交换机中的持久化队列spring_fanout_queue_2,不存在则自动创建-->
<rabbit:queue id="spring_fanout_queue_2" name="spring_fanout_queue_2" auto-declare="true"/>

<!--定义广播类型交换机;并绑定上述两个队列-->
<rabbit:fanout-exchange id="spring_fanout_exchange" name="spring_fanout_exchange" auto-declare="true">
    <rabbit:bindings>
        <rabbit:binding queue="spring_fanout_queue_1"/>
        <rabbit:binding queue="spring_fanout_queue_2"/>
    </rabbit:bindings>
</rabbit:fanout-exchange>

(5)定义定向类型交换机

<!--定义定向交换机中的持久化队列spring_direct_queue_1,不存在则自动创建-->
<rabbit:queue id="spring_direct_queue_1" name="spring_direct_queue_1" auto-declare="true"/>

<!--定义定向交换机中的持久化队列spring_direct_queue_2,不存在则自动创建-->
<rabbit:queue id="spring_direct_queue_2" name="spring_direct_queue_2" auto-declare="true"/>

<!--定义定向交换机,并绑定上述两个队列-->
<rabbit:direct-exchange name="spring_direct_exchange">
    <rabbit:bindings>
        <rabbit:binding queue="spring_direct_queue_1" key="direct_key_1"/>
        <rabbit:binding queue="spring_direct_queue_2" key="direct_key_2"/>
    </rabbit:bindings>
</rabbit:direct-exchange>

上述定义的是定向类型交换机,表示当routing key为direct_key_1的时候,会发送到spring_direct_queue_1,当routing key为direct_key_2的时候,会发送到spring_direct_queue_2。

(6)定义通配符类型交换机

<!--定义广播交换机中的持久化队列,不存在则自动创建-->
<rabbit:queue id="spring_topic_queue_1" name="spring_topic_queue_1" auto-declare="true"/>
<!--定义广播交换机中的持久化队列,不存在则自动创建-->
<rabbit:queue id="spring_topic_queue_2" name="spring_topic_queue_2" auto-declare="true"/>
<!--定义广播交换机中的持久化队列,不存在则自动创建-->
<rabbit:queue id="spring_topic_queue_3" name="spring_topic_queue_3" auto-declare="true"/>

<rabbit:topic-exchange id="spring_topic_exchange" name="spring_topic_exchange" auto-declare="true">
    <rabbit:bindings>
        <rabbit:binding pattern="abc.*" queue="spring_topic_queue_1"/>
        <rabbit:binding pattern="abc.#" queue="spring_topic_queue_2"/>
        <rabbit:binding pattern="*.cd" queue="spring_topic_queue_3"/>
    </rabbit:bindings>
</rabbit:topic-exchange>

上述代码表示:

(1)以abc.开头的routing key会转到spring_topic_queue_1,例如:abcabc.xxabc.xx.xxx

(2)以abc.开头的且只有一个单词的会转到spring_topic_queue_2,例如:abc.xx

(3)以".cd"结尾的的routing key会转到spring_topic_queue_3,例如:abc.cd,xx.cd

  • pattern:表示的路由器的通配符
    • * 表示0或多个单词
    • # 表示一个单词

(7)定义rabbitTemplate

<!--定义rabbitTemplate对象操作可以在代码中方便发送消息-->
<rabbit:template id="rabbitTemplate" connection-factory="connectionFactory"/>

1.4 代码测试

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:spring-rabbitmq-producer.xml")
public class ProducerTest {
    /**
     * 注入RabbitTemplate
     */
    @Autowired
    private RabbitTemplate rabbitTemplate;

    /**
     * 测试默认的队列发送消息
     */
    @Test
    public void test() {
        rabbitTemplate.convertAndSend("spring_queue", "hello world");
    }

    /**
     * 测试广播模式发送消息
     */
    @Test
    public void testFanout() {
        rabbitTemplate.convertAndSend("spring_fanout_exchange", "", "spring_fanout_exchange");
    }

    /**
     * 测试使用定向路由发送消息
     */
    public void testDirect() {
        // 将spring_direct_exchange_direct_key_1消息发送给路由key为direct_key_1的队列,即发送给spring_direct_queue_1
        rabbitTemplate.convertAndSend("spring_direct_exchange", "direct_key_1",
                "spring_direct_exchange_direct_key_1");
        // 将spring_direct_exchange_direct_key_2消息发送给路由key为direct_key_2的队列,即发送给spring_direct_queue_2
        rabbitTemplate.convertAndSend("spring_direct_exchange", "direct_key_2",
                "spring_direct_exchange_direct_key_2");
    }

    /**
     * 测试通配符模式
     */
    @Test
    public void testTopics() {
        rabbitTemplate.convertAndSend("spring_topic_exchange", "abc.cd", "spring_test_topics_abc.cd");
        rabbitTemplate.convertAndSend("spring_topic_exchange", "abc.x", "spring_test_topics_abc.x");
        rabbitTemplate.convertAndSend("spring_topic_exchange", "x.cd", "spring_test_topics_x.cd");
    }

}

2.消费者Spring-Consumer

2.1 创建消费者工程

消费者Spring-Consumer使用的jar包和生产者一样,无需修改。

<dependencies>
    <!-- https://mvnrepository.com/artifact/org.springframework/spring-context -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.springframework/spring-test -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>5.1.7.RELEASE</version>
        <scope>test</scope>
    </dependency>
    <!-- https://mvnrepository.com/artifact/junit/junit -->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
        <scope>test</scope>
    </dependency>
    <!-- https://mvnrepository.com/artifact/org.springframework.amqp/spring-rabbit -->
    <dependency>
        <groupId>org.springframework.amqp</groupId>
        <artifactId>spring-rabbit</artifactId>
        <version>2.1.8.RELEASE</version>
    </dependency>
</dependencies>

1.2 创建RabbitMQ配置文件

这里我们创建的是一个RabbitMQ配置文件,名称为rabbitmq.properties。目的是方便将配置文件中的信息加载到Spring中,就无需在xml文件中修改。

# RabbitMQ地址
rabbitmq.host=192.168.52.128
# RabbitMQ端口
rabbitmq.port=5672
# 用户名
rabbitmq.username=admin
# 密码
rabbitmq.password=admin
# 虚拟机
rabbitmq.virtual-host=/test

1.3 创建整合配置文件

RabbitMQ和Spring使用xml文件进行整合,意味着大部分的配置类或模板都在xml文件中,我们默认的文件名为:spring-rabbitmq-producer.xml

xml文件用到的默认约束

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:rabbit="http://www.springframework.org/schema/rabbit"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/context
       https://www.springframework.org/schema/context/spring-context.xsd
       http://www.springframework.org/schema/rabbit
       http://www.springframework.org/schema/rabbit/spring-rabbit.xsd">
</beans>

(1)加载配置文件,并创建连接工程connectionFactory

在这里我们需要注意的是加载配置文件的路径,classpath:rabbitmq.properties

<!--加载配置文件-->
<context:property-placeholder location="classpath:rabbitmq.properties"/>

<!-- 定义rabbitmq connectionFactory -->
<rabbit:connection-factory id="connectionFactory"
                           host="${rabbitmq.host}"
                           port="${rabbitmq.port}"
                           username="${rabbitmq.username}"
                           password="${rabbitmq.password}"
                           virtual-host="${rabbitmq.virtual-host}"/>
<!--将监听器加入ioc容器-->
<bean id="springQueueListener" class="org.example.listener.SpringQueueListener"/>
<!--创建listener-->
<rabbit:listener-container connection-factory="connectionFactory" auto-declare="true">
	<rabbit:listener ref="springQueueListener" queue-names="spring_queue"/>
</rabbit:listener-container>

(2)创建监听器Listener负责监听对应的队列消息

我们创建一个默认普通的监听器,用来监听spring_queue队列中的消息。

监听器默认要实现MessageListener接口,并实现onMessage方法。

public class SpringQueueListener implements MessageListener {
    @Override
    public void onMessage(Message message) {
        System.out.println("SpringQueueListener:" + new String(message.getBody()));
    }
}

(3)单元测试

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations = "classpath:spring-rabbitmq-consumer.xml")
public class ConsumerTest {

    @Test
    public void test() {
        while (true) {
        }
    }
}

控制台:SpringQueueListener:hello world

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
回答: Spring整合RabbitMQ主要包括以下几个步骤。首先,创建一个生产者类,例如ProducerTest,其中使用@Autowired注解注入RabbitTemplate对象,并使用convertAndSend方法发送消息到指定的队列,例如"spring_queue"。然后,创建一个消费者类,例如TopicTotalReceiver,使用@RabbitListener注解指定要监听的队列,例如"topic.woman",并在方法上使用@RabbitHandler注解处理接收到的消息。最后,在spring-rabbitmq-producer.xml文件中配置队列、交换机和绑定,例如使用<rabbit:queue>配置队列,使用<rabbit:direct-exchange>配置Direct类型的交换机,以及使用<rabbit:binding>进行绑定操作。这样就完成了SpringRabbitMQ整合配置。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Spring 整合RabbitMQ](https://blog.csdn.net/weixin_42947972/article/details/115219861)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* [SpringBoot整合RabbitMQ](https://blog.csdn.net/K_kzj_K/article/details/106642250)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卑微小钟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值