RabbitMQ是一个由Erlang语言开发的AMPQ的开源实现。

AMPQ:Advanced Message Queue Protocol,高级消息队列协议。它是应用层协议的一个开放标准,为面向消息的中间件设计,基于此协议的客户端与消息中间件之间可传递消息,并不受产品、开发语言等条件的影响。

特点
  • 可靠性(Reliability):rabbitMq使用一些机制来保证可靠性,如持久化,传输确认,发布确认。
  • 灵活的路由(Flexible Routing):在消息进入队列之前,通过Exchange来路由消息的。
  • 消息集群(Clustering):多个RabbitMQ服务器可组成一个集群,形成一个逻辑Broker。
  • 高可用(Highly Available Queues):队列可以在集群中的机器上进行镜像灌灌灌灌,使得在部分节点出问题的情况下仍然可用。
  • 多种协议(Mutil-protocol):RabbitMQ支持多种消息队列协议,比如STOMP、MQTT等
  • 多语言客户端(Many Clients):RabbitMQ几乎支持多有常用语言,比如 JAVA,.Net、Ruby等
  • 管理页面(Management UI):RabbitMQ提供了一个已用的用户界面,使得用户可以监控和管理消息Broker的虚度方面
  • 插件机制(Plugin System):RabbitMQ提供了许多插件,来从多方面进行扩展,也可以编写自己的插件
  • 跟踪机制(Tracing):如果消息异常,RabbitMQ提供了消息跟踪机制,使用者可以找出发生了什么