RabbitMQ是一个异步消息通信中间件,用erlang语言开发,实现了AMQP(Advanced Message Queue )协议,是一个开源产品,官方网站:http://www.rabbitmq.com/

应用场景。对于一个大型的软件系统来说,它会有很多的组件或者说模块或者说子系统或者(subsystem or Component or submodule)。那么这些模块的如何通信?这和传统的IPC有很大的区别。传统的IPC很多都是在单一系统上的,模块耦合性很大,不适合扩展(Scalability);如果使用socket那么不同的模块的确可以部署到不同的机器上,但是还是有很多问题需要解决。比如:

1)信息的发送者和接收者如何维持这个连接,如果一方的连接中断,这期间的数据如何方式丢失?

2)如何降低发送者和接收者的耦合度?

3)如何让Priority高的接收者先接到数据?

4)如何做到load balance?有效均衡接收者的负载?

5)如何有效的将数据发送到相关的接收者?也就是说将接收者subscribe 不同的数据,如何做有效的filter。

6)如何做到可扩展,甚至将这个通信模块发到cluster上?

7)如何保证接收者接收到了完整,正确的数据?

AMDQ协议解决了以上的问题,而RabbitMQ实现了AMQP。

消息队列的由来和发展过程。1983年,有个印度人Vivek Ranadive突发奇想,觉得软件系统中也应该有类似硬件总线的东西,其它的应用可以接到软件总线上,方便地实现应用间消息通信的工作。为此他创建了Teknekron公司,但直到1985年,他才终于找到了第一个客户高盛,以及软件总线天生用来解决的问题:金融交易。

当时的交易员的小隔间内挤满了用来完成交易的各种终端,每台终端显示不同类型的信息。如果用软件总线来处理各种不同类型的信息,那么交易员只需要一个终端来接入软件总线,订阅他想要的消息。于是发布订阅模式诞生了,同时诞生了第一个消息队列软件TIB(The Information Bus)。很快,这种数据传输模式便得到更广泛的应用,并进入了电信、新闻行业。1994年,路透社收购了Teknekron。

这个迅猛发展的软件很快得到了IBM的关注,因此在80年代后期,IBM开始研究自己的消息队列软件,1993年IBM MQ产品系列面世,之后的17年,MQ系列进化成了WebSphere MQ并统治着商业消息队列市场。那段时间,TIB也一直活在,后来更名为Rendezvous。1997年,Teknekron以TIBCO的形式作为一家独立公司再度出现。同年,微软也开发了自己的消息通信软件MSMQ

JMS(jave message service)的诞生。MQ软件几个供应商之间的壁垒森严,各个产品的通信协议、接口都不相同,如果你选择了一个产品,想要换另一个产品,显然需要修改接入应用。供应商的壁垒维持着足够高的价格和利润率,只有大型组织机构才能用的起MQ。为了打破壁垒,使得同一个应用可以消费不同的MQ产品,2001年,JMS诞生了。JMS提供公共的API接口,隐藏各个MQ产品的实际接口,这样应用程序只需要针对JMS API编程,选择合适的MQ驱动即可,JMS会打理好其它的部分。

AMQP(advanced message queuing protocol)的诞生。JMS虽然很好地胶合了各个MQ的接口,但是各个MQ的协议还是不一致,而且也不是开放的。显然有人并不满足以此。2004年,JPMorgan Chase和iMatix合作开发了AMQP,这是一个开放标准,任何人都可以执行这一标准,针对这一标准编码的任何人都可以和任意AMQP供应商提供的MQ交互。

RabbitMQ的由来。2004年,伦敦金融部门的企业家Alexis想要开一家公司去解决分布式环境下的通信问题,他认识到消息通信才是分布式计算的解决方案。这段时间AMQP正开始开发,他的金融背景使他认识了AMQP的主要负责人John O'Hara,于是准备基于AMQP来创建MQ服务。他找到Matthias探讨AMQP,Matthias对Erlang比较有研究,觉得Erlang很适合用来处理分布式消息通信,经过一番验证,2006年,他们成立了Rabbit Technologies公司来开发RabbitMQ。大家都觉得Rabbit这个名字不错,毕竟rabbit行动非常迅速,而且繁殖起来也很疯狂。刚好这时候AMQP草案也公开了,由于采用Erlang语言,让他们能快速开发并跟上AMQP标准前进的节奏。目前RabbitMQ得到了广泛的应用,从初创的小公司,到商业巨头。

RabbitMQ介绍1 - 由来的更多相关文章

  1. RabbitMQ介绍及安装部署

    本节内容: RabbitMQ介绍 RabbitMQ运行原理 RabbitMQ重要术语 三种ExchangeType RabbitMQ集群种类 集群基本概念 镜像模式部署集群 一.RabbitMQ介绍 ...

  2. RabbitMQ介绍及windows下安装使用

    RebbitMQ介绍 RabbitMQ是一个由 Erlang (一种通用的面向并发的编程语言)开发的AMQP(Advanced Message Queue )的开源实现,Rabbit MQ 是建立在E ...

  3. .net RabbitMQ 介绍、安装、运行

    RabbitMQ介绍 什么是MQ Message Queue(简称:MQ),消息队列 顾名思义将内容存入到队列中,存入取出的原则是先进先出.后进后出. 其主要用途:不同进程Process/线程Thre ...

  4. RabbitMQ介绍6 - 其它

    深入话题 Exchange实现路由的方法 http://www.rabbitmq.com/blog/2010/09/14/very-fast-and-scalable-topic-routing-pa ...

  5. RabbitMQ介绍5 - 集群

    RabbitMQ内建集群机制,利用Erlang提供的开放电信平台(OTP,Open telecom Platform)通信框架,使得集群很容易进行横向扩展,提高系统吞吐量.这里只讨论集群的概念.原理, ...

  6. RabbitMQ介绍4 - 编程(C#客户端示例)

    C#终端的说明文档: http://www.rabbitmq.com/dotnet-api-guide.html 这里介绍使用RabbitMQ的几种典型场景. 1. 简单direct模式( http: ...

  7. RabbitMQ介绍3 - 运行和管理RabbitMQ

    安装.官方介绍:http://www.rabbitmq.com/download.html.一般产品环境会部署到Linux环境,但做为简单尝试,可以部署到Windows上(这里是部署介绍:http:/ ...

  8. RabbitMQ介绍2 - AMQP协议

    这一节介绍RabbitMQ的一些概念,当然也是AMQP协议的概念.官方网站也有详细解释,包括协议的命令: http://www.rabbitmq.com/tutorials/amqp-concepts ...

  9. python使用rabbitMQ介绍三(发布订阅模式)

    一.模式介绍 在前面的例子中,消息直接发送到queue中. 现在介绍的模式,消息发送到exchange中,消费者把队列绑定到exchange上. 发布-订阅模式是把消息广播到每个消费者,每个消费者接收 ...

随机推荐

  1. springMVC源码学习之:springMVC响应请求的几种方法

    spring mvc 支持如下的返回方式:ModelAndView, Model, ModelMap, Map,View, String, void. ModelAndView @RequestMap ...

  2. Qt消息机制和事件(一)

    一,事件 事件(event)是由系统或者 Qt 本身在不同的时刻发出的.当用户按下鼠标.敲下键盘,或者是窗口需要重新绘制的时候,都会发出一个相应的事件.一些事件在对用户操作做出响应时发出,如键盘事件等 ...

  3. phpstorm编辑器智能提示框架代码

    按照上面的步骤就可以智能提示代码了!

  4. UserDefault的使用,保存小数据到本地-iOS

    //保持到本地数据 NSArray *array=@[@"234",@"sdfe"]; NSUserDefaults *userDefault=[NSUserD ...

  5. 谷歌 analytics.js 部分解密版

    源:http://www.google-analytics.com/analytics.js (function(){var aa=encodeURIComponent,f=window,ba=set ...

  6. pouchdb Conflicts

    Conflicts are an unavoidable reality when dealing with distributed systems. And make no mistake: cli ...

  7. Nagios 监控

    配置文件说明 文件名或目录名 用途 cgi.cfg 控制CGI访问的配置文件 nagios.cfg Nagios 主配置文件 resource.cfg 变量定义文件,又称为资源文件,在些文件中定义变量 ...

  8. gcc、g++

    http://hi.baidu.com/zhangcunli8499/item/257e187360b48b2bd6a89cc6 g++ src/*.cpp -I include/ -I includ ...

  9. sklearn小知识

    特征缩放:# 为了追求机器学习和最优化算法的最佳性能,我们将特征缩放 from sklearn.preprocessing import StandardScaler sc = StandardSca ...

  10. (四)文本编辑器Vim/Vi

    目录 前言 常用命令 扩展应用 总结 本系列先前的随笔位于新浪博客 前言 Vi和Vim都是文本编辑器,不同的是Vim是Vi的升级版本,它不仅兼容Vi的所有指令,而且还有一些新的特性在里面. Vim/V ...