RabbitMq 消息队列笔记 > AMPQ 基础概念说明
Rabbitmq 基础概念解释

下面图片展示了Rabbitmq的结构:

Publisher:

          是Message的生产者,Publisher这个Clients产生了一些Message。

Consumer:

          Message的消费者,Publisher产生的Message,最终要到达Consumer这个Clients,进行消费。

Exchange:

         指定消息按什么规则,路由到哪个Queue,Message消息先要到达Exchange,在Server中承担着从Produce接收Message的责任。

Queue:

         到达Exchange的消息,根据制定的规则(Routing key)到达对应的Queue,在Server中承担着装载Message,是Message的容器,等待被消费出去。

Routing key:

         在Exchange和Queue之间隐藏有一条黑线,可以将这条黑线看成是Routing key,Exchange就是根据这些定义好的Routing key将Message送到对应的Queue中去,是Exchange和Queue之间的桥梁。

Broker:

        之前一直不理解这个Broker,其实Broker就是接收和分发消息的应用,也就是说RabbitMQ Server就是Message Broker。

VirtualHost:

        虚拟主机,一个Broker里可以开有多个VirtualHost,它的作用是用作不同用户的权限分离。 

Connection:

       是Publisher/Consumer和Broker之间的TCP连接。断开连接的操作只会在Publisher/Consumer端进行,Broker不会断开连接,除非出现网络故障或者Broker服务出现问题,Broker服务宕了。

Connection: Channel: 

       如果每一次访问RabbitMQ就建立一个Connection,那在消息量大的时候建立TCP Connection的开销就会很大,导致的后果就是效率低下。