1、RabbitMQ简介
  MQ全称为Message Queue(消息队列),是一种“应用程序”<—>“应用程序”的通信方法。MQ是一个典型的“消费”<—>“生产者”模型的代表,生成者往消息队列中写入消息,消费者从消息队列中读取消息。
2、MQ的应用场景
  对于一个大型的软件系统来说,它会有很多的组件或者说模块或者说子系统或者(subsystem or Component or submodule)。那么这些模块的如何通信,mq就是用来实现各模块间通信的软件,开发人员只需关心自己相关的业务,不需要花费太多精力去处理模块间的通信。
3、MQ的几个重要的概念
1)RabbitMQ Server
  RabbitMQ is not a food truck, it’s a delivery service. 他的角色就是维护一条从Producer到Consumer的路线,保证数据能够按照指定的方式进行传输。

2)Producer
  数据的发送方。create messages and publish (send) them to a broker server (RabbitMQ).一个Message有两个部分:payload(发送的数据)和label(信息自带的标签,用来告诉RabbitMQ把这个信息发送到哪个Consumer)。
3)Consumer
  数据的接收方。Consumers attach to a broker server (RabbitMQ) and subscribe to a queue,把queue比作是一个有名字的邮箱。当有Message到达某个邮箱后,RabbitMQ把它发送给它的某个订阅者即Consumer,在这个Message中,只有payload,label已经被删掉了。
4)Exchanges
  Producer 发送消息到exchange。
5)Queues
   消息最终被送到这里等待consumer取走。一个message可以被同时拷贝到多个queue中。
6)Bindings
  exchange和queue之间的虚拟连接,binding中可以包含routing key。Binding信息被保存到exchange中的查询表中,用于message的分发依据。
7)Connection
  一个TCP的连接。Producer和Consumer都是通过TCP连接到RabbitMQ Server的,程序的起始处就是建立这个TCP连接。
8)Channels
  虚拟连接,它建立在上述的TCP连接中,数据流动都是在Channel中进行的,一般情况是程序起始建立TCP连接,第二步就是建立这个Channel。
4、ack机制
  如果一个queue没被任何的Consumer Subscribe(订阅),当这个queue有数据到达时,这些数据会被cache而不会被丢弃。当有Consumer订阅时,这些数据会被立即发送到这个Consumer,这些数据被Consumer正确收到后就被从queue中删除。
  什么是正确收到呢?通过ack。每个Message都要被acknowledged(确认,ack)。我们可以显示的在程序中去ack,也可以自动的ack。如果有数据没有被ack,那么RabbitMQ Server会把这个信息发送到下一个Consumer。
       如果这个app有bug,忘记了ack,那么RabbitMQ Server不会再发送数据给它,因为Server认为这个Consumer处理能力有限。
  ack的机制还可以起到限流的作用(Benefitto throttling):在Consumer处理完成数据后发送ack,甚至在额外的延时后发送ack,将有效的balance Consumer的load。
  比如我们可能会对某些数据进行merge,比如merge 4s内的数据,然后sleep 4s后再获取数据。特别是在监听系统的state,我们不希望所有的state实时的传递上去,而是希望有一定的延时。这样可以减少某些IO,而且终端用户也不会感觉到。
5、谁应该负责创建queue

  如果queue不存在,Consumer不会得到任何的Message。Producer Publish的Message也会被丢弃。所以,为了数据不丢失,Consumer和Producer都应try to create the queue。
  queue对load balance的处理是完美的。对于多个Consumer来说,RabbitMQ 使用循环的方式(round-robin)的方式均衡的发送给不同的Consumer。
6、Exchanges
  Procuder Publish的Message进入了Exchange。接着通过“routing keys”(路由键), RabbitMQ会找到应该把这个Message放到哪个queue里。queue也是通过这个routing keys来做的绑定,有三种类型的Exchanges:direct, fanout,topic。
7、Virtual hosts
      每个virtual host本质上都是一个RabbitMQ Server,拥有它自己的queue,exchagne,和bings rule等等。这保证了你可以在多个不同的application中使用RabbitMQ。

生产者发送消息到broker server(RabbitMQ)。在Broker内部,用户创建Exchange/Queue,通过Binding规则将两者联系在一起。Exchange分发消息,根据类型/binding的不同分发策略有区别。消息最后来到Queue中,等待消费者取走

最新文章

  1. 正在编译转换: 未能找到元数据文件 EntityFramework.dll
  2. Java 集合系列01之 总体框架
  3. smartjs 0.2 OOP讲解 - factory
  4. 六个字符,带你领略JavaScript (js的艺术编写)
  5. java 网络编程(二)----UDP基础级的示例
  6. Linux访问Windows磁盘实现共享
  7. 【Dancing Link专题】解题报告
  8. 解决服务器断电导致mysql数据库无法启动
  9. Android中的资源文件
  10. Linux命令:scp命令(文件上传和下载)
  11. 【转】sqlmap用户手册
  12. arm-linux-gnueabi和arm-linux-gnueabihf 的区别
  13. thinkphp中fetch渲染模板的处理
  14. 项目实战-使用PySpark处理文本多分类问题
  15. dd制作linux启动盘
  16. 设置TabBar图片
  17. 前端流程图jsplumb学习笔记
  18. ueditor自定义额外参数
  19. Redis持久化——RDB快照
  20. 【RF库Built-In测试】Catenate

热门文章

  1. Python:时间日历基本处理
  2. matplotlib显示AttributeError: &#39;module&#39; object has no attribute &#39;verbose&#39;
  3. 吴裕雄--天生自然TensorFlow2教程:单输出感知机及其梯度
  4. Python语言——map/reduce的用法
  5. vector 踩过的坑
  6. MySQL高级 InnoDB 和 MyISAM 的区别
  7. Java自学-集合框架 HashMap和Hashtable的区别
  8. JavaScript - 运行机制,作用域,作用域链(Scope chain)
  9. 工具,Linux - tree命令,显示程序树型结构
  10. PAT A1135 Is It A Red Black Tree