问题背景
在实际开发中,应用在使用期间可能既是消息生产者也是消息消费者的场景非常普遍,但可能消费的消息和生产的消息需要发送到不同的RabbitMQ服务示例或者同一个RabbitMQ示例下的不同vhost。在使用SpringBoot时,通过配置默认只能配置一个vhost,所以针对以上场景需要作出各自的配置。
解决方案
准备事项
添加maven依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
多vhost
配置文件配置链接RabbitMQ实例的基本信息,例如:
spring.rabbitmq.host=localhost
spring.rabbitmq.port=5672
spring.rabbitmq.username=guest
spring.rabbitmq.password=guest
#spring.rabbitmq.virtual-host=/
spring.rabbitmq.listener.simple.acknowledge-mode=manual
由于要使用多vhost,所以配置文件中的spring.rabbitmq.virtual-host可以不用设置,在后续JavaConfig中配置。
RabbitMQConfig.java,注意使用时各ConnectionFactory按名称区分,以免混淆。
@EnableRabbit
@Configuration
public class RabbitMQConfig {
/**
* {@link org.springframework.boot.autoconfigure.amqp.RabbitAutoConfiguration}
* 自动发送JSON结构或消费时自动将JSON转成相应的对象
*
* @return mq 消息序列化工具
*/
@Bean
public MessageConverter jsonMessageConverter() {
return new Jackson2JsonMessageConverter();
}
/**
* 默认的RabbitTemplate,vhost:/
*
* @param rabbitProperties
* @return
*/
@Bean("defaultConnectionFactory")
@Primary
public ConnectionFactory defaultConnectionFactory(RabbitProperties rabbitProperties) {
CachingConnectionFactory cachingC