发送消息
@Autowired
private RabbitTemplate rabbitTemplate;
@Test
void testSendMessage2Queue() {
String queueName = "simple.queue";
String msg = "hello, amqp!";
rabbitTemplate.convertAndSend(queueName, msg);
}
接收消息
@RabbitListener(queues = "simple.queue")
public void listenSimpleQueue(String msg){
System.out.println("消费者收到了simple.queue的消息:【" + msg +"】");
}
Work模型的使用:
1.多个消费者绑定到一个队列,可以加快消息处理速度
2.同一条消息只会被一个消费者处理
3.通过设置prefetch来控制消费者预取的消息数量,处理完一条再处理下一条,实现能者多劳。
Fanout交换机
真正生产环境都会经过exhange来发送消息,而不是直接发送到队列,交换机的类型有以下三种:
1.Fanout:广播
Fanout exchange 会将接收到的广播到每一个跟其绑定的queue
2.Direct:导向
Directt Exchange 会将接收到的消息更具规则路由到指定的Queue
每一个Queue都与Exchange设置一个BindingKey
发布者发送消息时,指定消息的RoutingKey
Exchange将消息路由到BindingKey与消息RoutingKey一致的队列
3.Topic:话题
Topic Exchange与Direct Exchange类似,区别在于routingKey可以是多个单词的列表,并且以 . 分割
Queue与Exchange指定BingKey时可以使用通配符:
#:代指0个或多个单词 例如 china.#
*:代指一个单词
声明队列和交换机
SpringAMQP提供了几个类,用雷声明队列,交换机及其绑定关系:
Queue:用于声明队列,可以用工厂类QueueBuilder构建
Exchange:用于声明交换机,可以用工厂类ExchangeBuilder构建
Binding:用于声明队列和交换机的绑定关系,可以用工厂类BindingBuilder构建
第二种方式: