SpringAMQP的使用
AMQP是一种消息通信的协议。
1.引入AMQP依赖
<!--AMQP依赖,包含RabbitMQ-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
2.publisher使用模板工具类,向队列发送消息
配置信息,添加mq连接所需要的信息:
spring:
rabbitmq:
host: 192.168.19.128 #rabbitMQ的ip地址
port: 5672 # 端口
username: itcast
password: 123321
virtual-host: /
发送信息示例代码:在publisher服务中新建一个测试类,编写测试方法。
@RunWith(SpringRunner.class)
@SpringBootTest
public class SpringAmqpTest {
@Autowired
private RabbitTemplate rabbitTemplate;
@Test
public void testSendMessage2SimpleQueue() {
String queueName = "simple.queue";
String message = "hello, spring amqp!";
rabbitTemplate.convertAndSend(queueName,message);
}
}
3.在consumer中编写消费逻辑,监听simple.queue
也需要在yml文件中添加rabbit配置。
监听消息代码:
@Component
public class SpringRabbitListener {
@RabbitListener(queues = "simple.queue")
public void listenSimpleQueue(String msg) {
System.out.println("消费者接收到simple.queue的消息:【" + msg + "】");
}
}
SpringAMQP Fanout交换机
1.在consumer服务声明Exchange、Queue、Binding
在consumer中新建一个类,添加@Configuration
注解,并声明FanoutExchange、Queue和绑定关系对象Binding,代码如下:
@Configuration
public class FanoutConfig {
// itcast.fanout
@Bean
public FanoutExchange fanoutExchange(){
return new FanoutExchange("itcast.fanout");
}
//fanout.queue1
@Bean
public Queue fanoutQueue1(){
return new Queue("fanout.queue1");
}
// 绑定队列1到交换机
@Bean
public Binding fanoutBinding1(Queue fanoutQueue1, FanoutExchange fanoutExchange){
return BindingBuilder
.bind(fanoutQueue1)
.to(fanoutExchange);
}
//fanout.queue2
@Bean
public Queue fanoutQueue2(){
return new Queue("fanout.queue2");
}
// 绑定队列2到交换机
@Bean
public Binding fanoutBinding2(Queue fanoutQueue2, FanoutExchange fanoutExchange){
return BindingBuilder
.bind(fanoutQueue2)
.to(fanoutExchange);
}
}
2.在consumer服务声明两个消费者,分别监听queue1和queue2
@RabbitListener(queues = "fanout.queue1")
public void listenFanoutQueue1(String msg) {
System.out.println("消费者接收到fanout.queue1的消息:【" + msg + "】");
}
@RabbitListener(queues = "fanout.queue2")
public void listenFanoutQueue2(String msg) {
System.out.println("消费者接收到fanout.queue2的消息:【" + msg + "】");
}
3.在publisher服务中发送消息到交换机
@Test
public void testFanoutExchange() {
// 交换机名称
String exchangeName = "itcast.fanout";
// 消息
String message = "hello, every one !";
// 发送消息
rabbitTemplate.convertAndSend(exchangeName,"",message);
}
SpringAMQP Direct交换机
1.消费者服务直接通过@RabbitListener注解绑定交换机,指定自身key,等待接收消息
@RabbitListener(bindings = @QueueBinding(
value = @Queue(name = "direct.queue1"),
exchange = @Exchange(name = "itcast.direct"),
key = {"red", "blue"}
))
public void listenDirectQueue1(String msg){
System.out.println("消费者接收到direct.queue1的消息:【" + msg + "】");
}
@RabbitListener(bindings = @QueueBinding(
value = @Queue(name = "direct.queue2"),
exchange = @Exchange(name = "itcast.direct"),
key = {"red", "yellow"}
))
public void listenDirectQueue2(String msg){
System.out.println("消费者接收到direct.queue2的消息:【" + msg + "】");
}
2.publisher服务指定routerkey发送消息,只有交换机中拥有指定的key的消费者可以收到消息
@Test
public void testSendDirectExchange() {
// 交换机名称
String exchangeName = "itcast.direct";
// 消息
String message = "hello, red!";
// 发送消息
rabbitTemplate.convertAndSend(exchangeName,"red",message);
}
Topic类型交换机
SpringAMQP中消息转换
消息传递中,传递对象的序列换与反序列化都是JDK的默认实现,可以将其修改为jackson实现。
xml依赖:
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
</dependency>
向spring容器中注入jackson序列化
@Bean
public MessageConverter messageConverter(){
return new Jackson2JsonMessageConverter();
}
发送消息
@Test
public void testSendObjectQueue() {
Map<String, Object> msg = new HashMap<>();
msg.put("name", "zhangsan");
msg.put("age", 33);
rabbitTemplate.convertAndSend("object.queue", msg);
}
接收消息
@RabbitListener(queues = "object.queue")
public void listenObjectQueue(Map<String, Object> msg){
System.out.println("消费者接收到direct.queue2的消息:" + msg);
}