rabbitMQ是市面上应用很广的一种应用间传送数据的通信方式,是由erlang语言开发,主要特点就是异步通信,实现服务与服务之间的解耦。
在其通信的过程中,有两个重要的角色,分别是生产者和消费者,需要强调的是RabbitMQ服务器并不产生任何消息,它只负责传递数据,由生产者创建消息,发布到RabbitMQ服务器,而消费者订阅了消息,并从RabbitMQ服务器获取消息。如下图所示
在RabbitMQ服务器中,存在一个交换器,可以理解成交换机拿了很多队列的钥匙,并把相应的消息放在队列中,在服务器中有四种交换器。下面我们逐个来进行介绍:
一个生产者对应一个消费者
一个生产者对应了多个消费者,但只有一个消费者可以获得消息,可用于负载均衡,让效率高的消费者负责多个消息
一个消费者将消息首先发送到交换器,交换器绑定到多个队列,然后被监听该队列的消费者所接收并消费。图中的X代表交换器
可以用于消费者选择性的接收消息
即我们的topix交换机进行模糊绑定。
以上的工作模式只需了解工作流程,具体的代码,后面的博客中会陆续讲到。
历史推荐
基于Nginx和Consul构建高可用及自动发现的Docker服务架构