消息队列可以实现流量削峰、降低系统耦合度、提高系统性能等。
RabbitMQ是一个实现了AMQP协议(Advanced Message Queue Protocol)的消息队列。
Amqp是一个提供统一消息服务的应用层标准高级消息队列协议,是应用层协议的一个开放标准,为面向消息的中间件设计。基于此协议的客户端与消息中间件可传递消息,并不受客户端/中间件同产品,不同的开发语言等条件的限制。
rabbitmq 有哪些重要的组件?
RabbitMQ消息传递(单个队列):
RabbitMQ消息传递(多个队列):
多个Queue的场景中,消息会被Exchange按一定的路由规则分发到指定的Queue中去:
每一类Exchange都有自己的分发路由规则:
Fanout Exchange:忽略key对比,发送Message到Exchange下游绑定的所有Queue
Direct Exchange:比较Message的routing key和Queue的binding key,完全匹配时,Message才会发送到该Queue
Topic Exchange:比较Message的routing key和Queue的binding key,按规则匹配成功时,Message才会发送到该Queue
默认Exchange:比较Message的routing key和Queue的名字,完全匹配时,Message才会发送到该Queue
RabbitMQ控制台可以:
原文:https://www.cnblogs.com/fan-1994716/p/11950827.html