目录
一、从思想上理解rabbitMQ的运转过程
很多时候,人都是自带无知属性,时不时暴露一下;
就像rabbitMQ,你不能只知道它是干什么用的,就觉得自己懂它了!!!
首先,先按照下图理解rabbitMQ的运转过程,以及动作的意义
上图流程中动作的意义:
一、生产者:指定“交换器”,就相当于进超市前去“储物区域”存放东西,设置路由规则就是“投放规则”,就是筛选给哪些储物柜(队列)里都放东西,而这些储物柜(队列)可能来自生产者指定而产生,也可能来自消费者声明而产生。
二、消费者:声明“交换器”,就相当于说去哪个“储物区域”取东西,声明队列就是在已指定的储物区安装一个“储物柜”,设置路由规则就是设置储物柜(队列)“接收规则”,总体而言就是将交换器和队列进行绑定。
注意:
若生产者不指定交换器,则会默认发送消息到默认交换器;
而消费者不声明交换器,则声明队列时会创建一个queue且都会有一个和queue同名的routingKey绑定到默认的exchange;
看完上述的,理解以后,就来熟悉上图中的各个组成部分就行了
使用组成:交换器、路由、队列
二、知悉RabbitMQ运转过程中的组成
交换机主要包括如下4种类型,以及各自的路由匹配规则:
交换机类型 | 路由匹配规则 |
Direct exchange(直连交换机) | 绑定路由key,相当于sql语句的 = |
Fanout exchange(扇型交换机) | 所有消费者都可以获取 |
Topic exchange(主题交换机) | 绑定通配符key,消费者根据通配符获取对应的消息 |
Headers exchange(头交换机) | 根据key-value进行绑定,消费者可以根据多个key进行获取消息 |
另外RabbitMQ默认定义一些交换机,在不指定交换机时会使用默认的:
- 默认交换机
- amq.* exchanges
在声明交换机时还可以附带其他的属性,重要且常用到的几个分别是:
- Name:交换机名称
- Durability:是否持久化。如果持久性,则RabbitMQ重启后,交换机还存在
- Auto-delete:当所有与之绑定的消息队列都完成了对此交换机的使用后,删掉它
- Arguments:扩展参数
以上的理论篇看完,那就可以开始代码实操了
未完待续,实际懒得写,思想理解了后,就会去掉脑袋里的疑惑,那几行代码随便一搜一大堆