Java高性能高并发秒杀系统(7)

1. 集成RabbitMQ

1.1 添加依赖

在这里插入图片描述

1.2 添加配置信息

在这里插入图片描述


2. 进行简单测试(Direct Exchange)

  • 任何发送到Direct Exchange的消息都会被转发到RouteKey中指定的Queue

2.1 创建一个配置类

1
2
3
4
5
6
7
8
9
10
11
@Configuration
public class MQConfig {

public static final String QUEUE_NAME = "queue";

@Bean
public Queue queue(){
return new Queue(QUEUE_NAME,true);
}
}
12345678910

2.1.1 @Bean注解

  • @Bean注解就是要告诉方法,产生一个Bean对象,并将这个Bean由Spring容器管理。产生这个Bean对象的方法Spring只会调用一次,随后这个Bean将放在IOC容器中。
  • SpringIOC容器管理一个或者多个Bean,这些Bean都需要在@Configuration注解下进行创建

2.2 创建消息的接受器

1
2
3
4
5
6
7
8
9
10
@Service
@Slf4j
public class MQReceiver {

@RabbitListener(queues = MQConfig.QUEUE_NAME)
public void receive(String message){
log.info("receive message:" + message);
}
}
123456789

2.2.1 @RabbitListener注解

  • @RabbitListener,其中queues属性通过识别队列的名字来接受消息进行消费

2.3 创建消息的发送器

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
@Service
@Slf4j
public class MQSender {

@Autowired
//AmqpTemplate接口定义了发送和接收消息的基本操作
AmqpTemplate amqpTemplate;

public void send(Object message){
String msg = RedisService.beanToString(message);
log.info("send message:" + msg);
amqpTemplate.convertAndSend(MQConfig.QUEUE_NAME,msg);
}
}
1234567891011121314

测试通过 ↓
在这里插入图片描述


3. 预先配置

在这里插入图片描述


4. Topic Exchange

  • 任何发送到Topic Exchange的消息都会被转发到与routingKey匹配的队列上

4.1 进行配置

在这里插入图片描述

4.2 编写消息发送者

在这里插入图片描述

4.3 编写消息接收器

在这里插入图片描述

4.4 测试结果

  • 我们只绑定了队列1和队列2,根据消息发送者,会为队列1和队列2各发送一条消息,队列1和队列2各收到一条消息
  • 测试内容
    在这里插入图片描述
  • 测试结果
    在这里插入图片描述

5. Fanout Exchange

  • 任何发送到Fanout Exchange的消息都会被转发到与之绑定的队列上

5.1 进行配置

在这里插入图片描述

5.2 编写消息发送者

在这里插入图片描述

5.3 编写消息接受器

在这里插入图片描述

5.4 测试结果

  • 根据条件,我们可以知道Fanout Exchange进行广播,每个队列都会收到消息
  • 测试内容在这里插入图片描述
  • 测试结果
    在这里插入图片描述

6. Headers Exchange

  • 任何发送到Headers Exchange的消息,都会和其中存储的条件进行匹配,有whereall和whereAny的区别(全部匹配/任何匹配)

6.1 进行配置

在这里插入图片描述

6.2 编写消息发送者

在这里插入图片描述

6.3 编写消息接收器

在这里插入图片描述

6.4 测试结果

  • 根据匹配条件我们可以知道,只有3队列能接受到消息。
  • 测试内容在这里插入图片描述
  • 测试结果