1.三种Exchange类型
(1)fanout(扇形)
把所有发送到该Exchange的消息路由到所有与它绑定的Queue中,
生产者:定义1个FanoutExchange及多个Queue,并把Queue绑定到该Exchange,发送时发送到该Exchange中即可,routingKey传空值,消息会同时到这多个Queue中
消费者:监听指定Queue并处理
(2)direct(直连)
把消息路由到那些binding key与routing key完全匹配的Queue中
生产者:定义1个DirectExchange及1个或多个Queue,并把Queue通过binding key(其实代码里是routing key)绑定到该Exchange,发送时发送到该Exchange中,并指定routingKey,消息到这routingKey相同的1个或多个Queue中
消费者:监听指定Queue并处理
(3)topic(主题)
direct类型的Exchange路由规则是完全匹配binding key与routing key,但这种严格的匹配方式在很多情况下不能满足实际业务需求。topic类型的Exchange在匹配规则上进行了扩展,它与direct类型的Exchage相似,也是将消息路由到binding key与routing key相匹配的Queue中,但这里的匹配规则有些不同,它约定:
- routing key为一个句点号“. ”分隔的字符串(我们将被句点号“. ”分隔开的每一段独立的字符串称为一个单词),如“stock.usd.nyse”、“nyse.vmw”、“quick.orange.rabbit”
- binding key与routing key一样也是句点号“. ”分隔的字符串
- binding key中可以存在两种特殊字符“*”与“#”,用于做模糊匹配,其中“*”用于匹配一个单词,“#”用于匹配多个单词(可以是零个)
生产者:定义1个TopicExchange及1个或多个Queue,也是把Queue通过binding key(其实代码里是routing key)绑定到该Exchange,但此时的binding key是可以模糊的,发送时发送到该Exchange中,并指定routingKey(精确的),消息到这匹配binding key的1个或多个Queue中
消费者:监听指定Queue并处理
注意:多个消费者同时监听同一个Queue,消息会平均分摊给多个消费者
2.开发示例-生产者
springboot开发
(1)引入jar依赖
<!--rabbitmq-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-amqp</artifactId>
</dependency>
(2)引入配置(因为本次使用了HAProxy代理,否则默认端口应该5672)
spring:
application:
name: rabbitmq-provider
rabbitmq:
host: 192.168.166.159
port: 9189
username: admin
password: admin
(3)fanout(扇形)类型的代码示例
①定义队列及FanoutExchange
import org.springframework.amqp.core.Binding;
import org.springframework.amqp.core.BindingBuilder;
import org.springframework.amqp.core.FanoutExchange;
import org.springframework.amqp.core.Queue;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
public class FanoutRabbitCo