交换机的fault (发布与订阅模式)
因为消息是由生产者发送给excahnge,exchange发送给队列, 然后由队列发送给消费者的。
展示使用图形化界面使用fanout模式。
创建交换机
然后创建三个队列,绑定对应的交换机,发现给交换机发送消息给队列, 3个队列同都收到了消息
direct模式
相对于发布订阅模式就是加了一个路由Key,如果说,消息的key是相同的,那么exchange就发送给对应的队列。
这个东西就像一个数据库, queue就相几张表, 交换机就往里面发数据。批量发,条件发。
和上面的一样,不过 使用 direct模式的交换机,可以指定路由key,也可以不指定路由key,
不过,如果是设置由
如果说是一个没有routKey的消息发送,那么就会发送给那些没有路由的队列
如果说 是由routkey的,那么就只会发送消息给那些 队列中由routkey的队列
主题模式的交换机(topic)
可以看到主题模式相对于direct模式来说,添加了模糊匹配的路由规则
这里只是需要了解到 *的意思是一个,有且只有一个
#是一个或者多个。
headers的主题模式,带有参数的模式。
参数就是Arguments ,如果是代码的话就是props代表里面的参数显示。
上面的都是图形化的界面的显示。 下面使用springboot进行整合
fanout 发布订阅模式
应用场景:
用户再下单之后相多个服务发送了短信推送服务、邮件服务、sms短信服务、微信推送服务
如果说在没有使用中间件的情况下,肯定是使用线程池,将每个消息都进行线程推送
但是这样 jvm中开启多个线程就十分的消耗资源,然后使用线程的过程中也是十分占用内存的资源,所以这个选择再开一台服务器,代替来工作,减少单台服务器的压力。