RabbitMQ及AMQP基本概念

       Rabbitmq是目前使用非常广泛的消息中间件,它是基于AMQP(Advanced Message Queue Protocol 高级消息队列协议)协议实现的。AMQP是具有现代特征的二进制协议,是一个提供统一消息服务的应用层标准高层消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。

一.虚拟主机 virtual host

     虚拟主机是一个虚拟的地址,用于进行逻辑隔离,是最上层的消息路由。一个 virtual host里面可以有若干个Exchange和Queue,但同一个virtual host里面不能有相同名称的Exchange或Quene。

二.交换机Exchange

交换机Exchange负责接收消息,根据路由配置转发消息到绑定的队列。交换机的主要类型有:direct、topic、fanout。

1.Direct Exchange

       所有发送到Direct Exchange的消息将被转发到routingkey中指定的Queue。
       消息生产者要指定exchange,然后通过路由规则,把消息路由到指定的队列。如果不指定exchange而是输入空字符串,可以使用RabbitMQ自带的Exchange,就会按照routingkey去找完全匹配的队列名,必须完全匹配才会被队列接收,否则就消息会被抛弃。
       直连direct方式,发送端和接收端的routingkey必须一致。或者发送端的routingkey与接收quene的name一致,这种情况就与不指定exchange的方式类似。

2.Topic Exchange

       所有发送到Topic Exchange的消息会被转发到所有绑定该Topic并匹配Routingkey的队列上。Topic与Routingkey进行模糊匹配。

3.Fanout Exchange

       fanout类型不处理路由键,性能是所有exchange中最快的。消息会被转发到与该交换机绑定的所有队列上。

三.队列Queue

       Queue负责保存消息并将它们转发给消费者。

四.Binding

       Binding是Exchange与Queue之间的虚拟连接,binding中可以包含routing key。routing key是一个路由规则,可用它来确定一个特定路由。

五.网络信道Channel

       几乎所有的操作都在channel中进行,是进行消息读写的通道。客户端可建立多个channel,每个channel代表一个会话任务。
在实际工作中特别要注意,消息发送者发送完消息后,一定要记得关闭连接。关闭连接要由小到大关闭。

//记得要关闭相关的连接
channel.close();
connection.close();

六.Message

      消息Message,是服务器与应用程序之间传送的数据,由Properties和body组成。Properties可定义一些消息的属性,比如消息优先级,过期时间等;body则是消息体的具体内容。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值