rabbitmq与spring的整合

rabbitMQ

消息队列,主要解决异步消息的管理(注册后,短信发送不是必须,可以使用队列)。实现系统之间的双向解耦,同时也能起到消息缓冲,消息分发的作用。当生产者产生大量数据,而消费者无法快速消费,(秒杀数据量过大使系统崩溃,队列可以废弃多余请求),或者是消费者异常了(服务挂掉后使请求丢失,队列可以保存请求)。

rabbitmq与spring的整合

其中p为生产者(发送请求) C是消费者(获取请求),红线为队列,X为交换机,生产者把请求给交换机 ,交换机把请求按照一定绑定关系发送给队列(平均发送),然后队列在把请求给消费者。其中交换机只负责转发并不负责保存,然后通过绑定关系与队列相绑定。

交换机类型

fanout:发送给所有绑定该交换机的队列。

Direct:默认的交换方法,按照提供的key去寻找队列。如果key为A,数据只能发送到A的队列中。

Topic:模糊匹配,只要符合该格式就可以。可以存在两种特殊字符“*”与“#”,用于做模糊匹配,其中“*”用于匹配一个单词,“#”用于匹配多个单词(可以是零个)。如*.C.# 可以匹配A.C.B.不能匹配A.B.C.

head:根据消息内容中的headers属性进行匹配。

使用的工具类

        ConnectionFactory、Connection、Channel都是RabbitMQ对外提供的API中最基本的对象。Connection是RabbitMQ的socket链接,它封装了socket协议相关部分逻辑。ConnectionFactory为Connection的制造工厂。
  Channel是我们与RabbitMQ打交道的最重要的一个接口,我们大部分的业务操作是在Channel这个接口中完成的,包括定义Queue、定义Exchange、绑定Queue与Exchange、发布消息等。

 

 

 

 

 

 

 

安装可以参考 https://www.cnblogs.com/junrong624/p/4121656.html