需求
类似多对多的关系 主要在于路由key的模糊匹配
生产者
pom.xml App.java QueueTest.java 同上一篇 Direct交换器
application.yml
#rabbitmq 基础配置 链接 账号 密码 同上一篇 Direct交换器
.......
#交换器的名称
mq.config.exchange: log.topic
UserSender.java
import org.springframework.amqp.core.AmqpTemplate;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
/**
* 消息发送者
* @author Administrator
*
*/
@Component
public class UserSender {
@Autowired
private AmqpTemplate rabbitAmqpTemplate;
//exchange 交换器名称
@Value("${mq.config.exchange}")
private String exchange;
/*
* 发送消息的方法
*/
public void send(String msg){
//向消息队列发送消息
//参数一:交换器名称。
//参数二:路由键
//参数三:消息
this.rabbitAmqpTemplate.convertAndSend(this.exchange, "user.log.info", "user.log.info......"+msg);
this.rabbitAmqpTemplate.convertAndSend(this.exchange, "user.log.error", "user.log.error......"+msg);
}
}
消费者
pom.xml App.java 同上一篇 Direct交换器
application.yml
#rabbitmq 基础配置 链接 账号 密码 同上一篇 Direct交换器
.......
#设置交换器的名称
mq.config.exchange: log.topic
#info 队列名称
mq.config.queue.info: log.info
#error 队列名称
mq.config.queue.error: log.error
InfoReceiver.java
import org.springframework.amqp.core.ExchangeTypes;
import org.springframework.amqp.rabbit.annotation.Exchange;
import org.springframework.amqp.rabbit.annotation.Queue;
import org.springframework.amqp.rabbit.annotation.QueueBinding;
import org.springframework.amqp.rabbit.annotation.RabbitHandler;
import org.springframework.amqp.rabbit.annotation.RabbitListener;
import org.springframework.stereotype.Component;
/**
* 消息接收者
* @author Administrator
* @RabbitListener bindings:绑定队列
* @QueueBinding value:绑定队列的名称
* exchange:配置交换器
*
* @Queue value:配置队列名称
* autoDelete:是否是一个可删除的临时队列
*
* @Exchange value:为交换器起个名称
* type:指定具体的交换器类型
*/
@Component
@RabbitListener(
bindings=@QueueBinding(
value=@Queue(value="${mq.config.queue.info}",autoDelete="true"),
exchange=@Exchange(value="${mq.config.exchange}",type=ExchangeTypes.TOPIC),
key="*.log.info"
)
)
public class InfoReceiver {
/**
* 接收消息的方法。采用消息队列监听机制
* @param msg
*/
@RabbitHandler
public void process(String msg){
System.out.println("Info........receiver: "+msg);
}
}
ErrorReceiver.java
@RabbitListener(
bindings=@QueueBinding(
value=@Queue(value="${mq.config.queue.error}",autoDelete="true"),
exchange=@Exchange(value="${mq.config.exchange}",type=ExchangeTypes.TOPIC),
key="*.log.error"
)
)
测试流程
先运行消费者的App.java
再运行生产者的测试代码
备注:
如果ExchangeTypes设置错误,但是运行了代码 需要到RabbitMq 后台把Exchange给删掉,再重新运行程序