19、RabbitMQ与AMQP:消息系统的全面解析

RabbitMQ与AMQP:消息系统的全面解析

1. 主题交换器与消息绑定

在消息系统中,主题交换器(topic exchange)是一种强大的交换器类型。它允许通过特定的绑定键(binding key)来筛选消息。例如,如果要获取包含 name 字段的任何修改消息,可以使用 #.name.# 进行绑定,这里的 # 表示零个或多个令牌,即“零个或多个令牌,中间包含 name 令牌,后面再跟零个或多个令牌”。若只想获取关于 name 字段更新的消息,则使用 update.#.name.# 进行绑定。

主题交换器虽然功能强大,但在性能方面,直接交换器(direct exchange)和扇形交换器(fanout exchange)通常表现更好。选择哪种交换器取决于具体的设置。交换器上的绑定数量越少,性能问题就越不明显。随着绑定数量的增加,对于每个传入的消息,需要进行更多的检查。因此,有时为每个需要消息传递功能的服务创建多个交换器是个不错的主意。

2. 持久性与持久化

2.1 持久性(Durability)

持久性指的是交换器或队列在服务器重启或崩溃后仍能存活的能力。在RabbitMQ中,可以在队列和交换器上设置持久性。需要注意的是,即使队列是持久的,并不意味着队列中的消息也是持久的。此外,如果一个交换器被标记为持久的,那么只有持久的队列才能绑定到该交换器,反之亦然。

2.2 持久化(Persistence)

持久化是指

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值