spring boot整合rabbitmq

这是我参与11月更文挑战的第7天,活动详情查看:2021最后一次更文挑战

1.spring boot整合rabbitmq

代码思路:在配置文件中定义队列(queue),交换机(exchange),然后队列与交换器以路由键名称相对应(路由键和队列名相匹配,既以路由键寻找对列名),然后生产者可以通过交换器和队列名称确定要发送的队列,而消费者选择监控队列,来获取消息。

在整合之前需要安装rabbitmq,然后启动和搭建框架。

1.Direct交换机

1.新建队列与绑定关系
1
2
3
4
5
6
7
8
9
10
js复制代码@Configuration
public class RabbitMQConfig {

// -------------------------topic队列
// 创建队列
@Bean
public Queue topicQueue() {
return new Queue("topic.mess");
}
}
2.生产者

直接配置一个队列,然后调用API发送消息就可以了。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
js复制代码public class ProducerController {
@Autowired
private RabbitTemplate rabbitTemplate;

@GetMapping("/sendMessage")
public Object sendMessage() {
new Thread(() -> {
//for (int i = 0; i < 100; i++) {

Date date = new Date();
String value = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss").format(date);
System.out.println("send message {}" + value);
City city= new City();
city.setCityName("aaaa");
city.setDescription("bbb");
city.setProvinceId((long)111);
rabbitTemplate.convertAndSend("topic.mess", city); //使用默认的队列

//}
}).start();
return "ok";
}
}
3.消费者

消费者直接使用就可以了(可以传对象 基本类型)。需要@RabbitListener注解。

1
2
3
4
5
6
7
8
9
js复制代码@Component
@RabbitListener(queues = "topic.mess") //topic交换机
public class Consumer2 {

@RabbitHandler
public void consumeMessage(City city) {
System.out.println("consume message {} 2222222:" + city);
}
}

2.topic交换机

1.新建队列与绑定关系

声名两个队列和一个topic交换器,然后通过路由键绑定他们之间的关系,路由键和队列名相同就能匹配,但是topic可以模糊匹配 #可以代替一段字符。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
js复制代码@Configuration
public class RabbitMQConfig {

// -------------------------topic队列
// 创建队列
@Bean
public Queue topicQueue() {
return new Queue("topic.mess");
}

@Bean
public Queue topicQueue2() {
return new Queue("topic.mess2");
}

// 创建 topic 类型的交换器
@Bean
public TopicExchange topicExchange() {
return new TopicExchange("topic");
}


// 使用路由键(routingKey)把队列(Queue)绑定到交换器(Exchange) Topic交换器通过routingKey与队列绑定
@Bean
public Binding bindingA(Queue topicQueue, TopicExchange topicExchange) {
return BindingBuilder.bind(topicQueue).to(topicExchange).with("topic.mess");
}

@Bean
public Binding bindingB(Queue topicQueue2, TopicExchange topicExchange) {
return BindingBuilder.bind(topicQueue2).to(topicExchange).with("topic.#");
}
}
2.生产者

直接调用API发送消息。消费者发送到队列,因为有模糊匹配的规则,topic.mess可以匹配 topic.mess和topic.mess2队列 而topic.mess2只能匹配到topic.#。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
js复制代码@RestController
public class ProducerController {
@Autowired
private RabbitTemplate rabbitTemplate;

@GetMapping("/sendMessage")
public Object sendMessage() {
new Thread(() -> {
//for (int i = 0; i < 100; i++) {

Date date = new Date();
String value = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss").format(date);
System.out.println("send message {}" + value);
City city= new City();
city.setCityName("aaaa");
city.setDescription("bbb");
city.setProvinceId((long)111);
rabbitTemplate.convertAndSend("topic", "topic.mess", city);
rabbitTemplate.convertAndSend("topic", "topic.mess2", city);
//}
}).start();
return "ok";
}
}
3.消费者

消费者直接接收。

1
2
3
4
5
6
7
8
9
js复制代码@Component
@RabbitListener(queues = "topic.mess") //topic交换机
public class Consumer2 {

@RabbitHandler
public void consumeMessage(City city) {
System.out.println("consume message {} 2222222:" + city);
}
}

3.Fanout Exchange 广播

1.新建队列与绑定关系

在配置文件中声名队列和交换器,然后绑定。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
js复制代码// --------FanoutExchange绑定
// -------------------------Fanout 队列
@Bean
FanoutExchange fanoutExchange() {
return new FanoutExchange("fanoutExchange");
}
@Bean
public Queue fanoutQueue() {
return new Queue("fanoutqueue");
}
@Bean
public Queue fanoutQueue2() {
return new Queue("fanoutqueue2");
}
@Bean
public Binding bindingC(Queue fanoutQueue, FanoutExchange fanoutExchange) {
return BindingBuilder.bind(fanoutQueue).to(fanoutExchange);
}
@Bean
public Binding bindingD(Queue fanoutQueue2, FanoutExchange fanoutExchange) {
return BindingBuilder.bind(fanoutQueue2).to(fanoutExchange);
}
2.生产者

调用API发送消息。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
js复制代码@RestController
public class ProducerController {
@Autowired
private RabbitTemplate rabbitTemplate;

@GetMapping("/sendMessage")
public Object sendMessage() {
new Thread(() -> {
//for (int i = 0; i < 100; i++) {

Date date = new Date();
String value = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss").format(date);
System.out.println("send message {}" + value);
City obj = new City();
obj.setCityName("aaaa");
obj.setDescription("bbb");
obj.setProvinceId((long)111);
rabbitTemplate.convertAndSend("fanoutExchange","", value); //使用默认的队列

//}
}).start();
return "ok";
}
}
3.消费者

然后接收,所有绑定队列的都可以接收到。

1
2
3
4
5
6
7
8
9
js复制代码@Component
@RabbitListener(queues = "fanoutqueue2")
public class Consumer {

@RabbitHandler
public void consumeMessage(String message) {
System.out.println("consume message {} 1111111:" + message);
}
}

本文转载自: 掘金

开发者博客 – 和开发相关的 这里全都有

0%