spring配置rabbitMQ监听

本文详细介绍如何在Spring Boot项目中配置和使用RabbitMQ,包括连接工厂设置、队列声明、消息转换器配置及监听容器的实现。
<?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"
	xmlns:task="http://www.springframework.org/schema/task"  
	xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context-4.3.xsd
           http://www.springframework.org/schema/rabbit https://www.springframework.org/schema/rabbit/spring-rabbit.xsd
           http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task.xsd">
           
    <context:property-placeholder location="classpath:profile.dev.properties" ignore-unresolvable="true" />
	<context:component-scan base-package="com.test.rabbitmq.listener" />  
	<!-- spring amqp默认的是jackson 的一个插件,目的将生产者生产的数据转换为json存入消息队列 -->  
    <!-- <bean id="jsonMessageConverter"  class="org.springframework.amqp.support.converter.Jackson2JsonMessageConverter"/>   -->
    
	<!-- 创建connectionFactory --> 	
    <!-- org.springframework.amqp.rabbit.connection.CachingConnectionFactory -->
    <task:executor id="mqExecutor" pool-size="20-100" keep-alive="600"  queue-capacity="2000" rejection-policy="CALLER_RUNS" />

	<rabbit:connection-factory id="connectionFactory"
		host="${rabbit.host}" 
		port="${rabbit.port}"
		username="${rabbit.username}"
		password="${rabbit.password}" 
		channel-cache-size="1000"
		executor="mqExecutor"/>
	<!-- org.springframework.amqp.rabbit.core.RabbitAdmin -->
	<rabbit:admin connection-factory="connectionFactory" auto-startup="true" ignore-declaration-exceptions="true"/>

	<!-- 声明MQ队列 -->
	<rabbit:queue id="queueName" name="queueName" durable="true" auto-delete="false" exclusive="false" />
		
	<task:annotation-driven scheduler="myScheduler"/>
    <task:scheduler id="myScheduler" pool-size="8" />
    
    <bean id="simpleMessageConverter"
		class="org.springframework.amqp.support.converter.SimpleMessageConverter">
		<property name="createMessageIds" value="true" />
	</bean>
	<!-- MQ消费者监听容器 -->
	<bean id="receiveMessageListener" class="com.test.rabbitmq.listener.RabbitMQMessageListener"/>
	
	<rabbit:listener-container connection-factory="connectionFactory" acknowledge="auto" requeue-rejected="false"   
	      concurrency="20" message-converter="simpleMessageConverter" > 
    	    <rabbit:listener ref="receiveMessageListener" method="onMessage" queues="queueName" />
     </rabbit:listener-container>

</beans>

 

### Spring框架中配置RabbitMQ的消息队列服务 在Spring框架中配置RabbitMQ的消息队列服务涉及多个方面,包括依赖引入、基本配置以及具体的生产者和消费者的实现。以下是详细的说明: #### 1. 添加Maven依赖 为了使Spring项目能够支持RabbitMQ功能,需要在`pom.xml`文件中添加以下依赖项[^1]: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> ``` #### 2. 配置application.properties或application.yml 在项目的配置文件中设置RabbitMQ的相关参数,例如主机地址、端口、用户名和密码等。以下是一个典型的配置示例: 对于`application.properties`: ```properties spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=guest spring.rabbitmq.password=guest ``` 或者对于`application.yml`: ```yaml spring: rabbitmq: host: localhost port: 5672 username: guest password: guest ``` #### 3. 创建队列和交换机 可以通过Java代码动态创建队列和交换机。下面展示了一个简单的例子[^4]: ```java import org.springframework.amqp.core.Queue; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; @Configuration public class RabbitConfig { @Bean public Queue testQueue() { return new Queue("test_spring_queue_1", true); } } ``` #### 4. 实现消息生产者 定义一个类来发送消息到指定的队列。以下是一个简单的消息生产者的实现: ```java import org.springframework.amqp.rabbit.core.RabbitTemplate; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; @Service public class MessageProducer { private final RabbitTemplate rabbitTemplate; @Autowired public MessageProducer(RabbitTemplate rabbitTemplate) { this.rabbitTemplate = rabbitTemplate; } public void sendMessage(String message) { rabbitTemplate.convertAndSend("test_spring_queue_1", message); } } ``` #### 5. 实现消息消费者 通过监听器模式消费来自队列的消息。以下是一个典型的消息消费者的实现: ```java import org.springframework.amqp.rabbit.annotation.RabbitListener; import org.springframework.stereotype.Component; @Component public class MessageConsumer { @RabbitListener(queues = "test_spring_queue_1") public void receiveMessage(String message) { System.out.println("Received message: " + message); } } ``` #### 6. 启动与管理RabbitMQ服务 确保本地已正确安装并运行RabbitMQ服务。可以使用以下命令进行操作[^3]: - **启动服务**:`net start RabbitMQ` - **停止服务**:`net stop RabbitMQ` - **查看状态**:`rabbitmqctl status` - **启用管理插件**:`rabbitmq-plugins enable rabbitmq_management` 访问管理界面可通过浏览器打开默认路径 `http://localhost:15672/` 并登录,默认账户为 `guest/guest`[^2]。 --- ### 总结 以上步骤涵盖了从环境准备到具体编码实现的过程,帮助开发者快速上手Spring框架下的RabbitMQ消息队列服务配置
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值