RabbitMQ概念

异步调用的优势是什么?

耦合度低,扩展性强

异步调用,无需等待,性能好

故障隔离,下游服务故障不影响上游业务

缓存消息,流量削峰填谷

异步调用的问题:

不能立刻得到调用结果,时效性差。

不确定下游业务执行是否成功。

业务安全依赖于Broker的可靠性。

MQ,中文是消息队列,字面来看就是存放消息的队列,也就是异步调用中的Broker。

Work模型的使用:

多个消费者绑定到一个队列,可以加快消息处理速度

同一个消息只会被一个消费者处理

通过设置prefetch来控制消费者预取的消息数量,处理完一条在处理下一条,实现能者多劳。

fanout交换机

fanout Exchange 会将接收到的消息广播到每一个跟其绑定的queue,所以也叫广播模式。

交换机的作用是什么?

接收publisher发送的消息。

将消息按照规则路由到与之绑定的队列

FanoutExchange的会将消息路由到每个绑定的队列。

Diect交换机

Direct Exchange 会将接受到的消息根据规则路由到指定的Queue,因此称为定向路由。

每一个Queue都与Exchange设置一个BindingKey

发布者发送消息时,指定消息的routingKey.

exchange将消息路由到BindingKey与RoutingKey一致的队列。

Topic交换机

TopicExchange与DirectExchange类似,区别在于routingKey可以时多个单词的列表,并且以.分割。

声明队列和交换机

SpingAMQP提供了几个类,用来声明队列、交换机及其绑定关系:

Queue:用于声明队列,可以用工厂类QueueBuilder构建

Exchage:用于声明交换机,可以用工厂类ExchangeBuilder构建

Binding:用于声明队列和交换机的绑定关系,可以用工厂类BindingBuilder构建

相关推荐
大数据CLUB3 小时前
基于spark的澳洲光伏发电站选址预测
大数据·hadoop·分布式·数据分析·spark·数据开发
ajax_beijing5 小时前
zookeeper是啥
分布式·zookeeper·云原生
虫小宝11 小时前
返利app的消息队列架构:基于RabbitMQ的异步通信与解耦实践
分布式·架构·rabbitmq
We....11 小时前
Java分布式编程:RMI机制
java·开发语言·分布式
在未来等你12 小时前
Elasticsearch面试精讲 Day 18:内存管理与JVM调优
大数据·分布式·elasticsearch·搜索引擎·面试
We....12 小时前
Java 分布式缓存实现:结合 RMI 与本地文件缓存
java·分布式·缓存
Chasing__Dreams12 小时前
kafka--基础知识点--5.3--producer事务
分布式·kafka
小枫编程12 小时前
Spring Boot 调度任务在分布式环境下的坑:任务重复执行与一致性保证
spring boot·分布式·后端
Hello.Reader14 小时前
Kafka 实现从网络层到日志与位点的“全景拆解”
分布式·kafka
无缘之缘14 小时前
SpringBoot整合RabbitMQ
spring boot·rabbitmq·java-rabbitmq