源地址: https://www.cnblogs.com/hz04022016/p/6518138.html

RabbitMQ是流行的开源消息队列系统,用erlang语言开发。RabbitMQ是AMQP(高级消息队列协议)的标准实现。

RabbitMQ中间件分为服务端(RabbitMQ Server)和客户端(RabbitMQ Client),服务端可以理解为是一个消息的代理消费者,客户端又分为消息生产者(Producer)和消息消费者(Consumer)。

  1、消息生产者(Producer):主要生产消息并将消息基于TCP协议,通过建立Connection和Channel,将消息传输给RabbitMQ Server,对于Producer而言基本就完成了工作。

  2、服务端(RabbitMQ Server):主要负责处理消息路由、分发、入队列、缓存和出列。主要由三部分组成:Exchange、RoutingKey、Queue。

    (1)Exchange:用于接收消息生产者发送的消息,有三种类型的exchange:direct, fanout,topic,不同类型实现了不同的路由算法;

    A. direct exchange:将与routing key 比配的消息,直接推入相对应的队列,创建队列时,默认就创建同名的routing key。

    B. fanout exchange:是一种广播模式,忽略routingkey的规则。

    C. topic exchange:应用主题,根据key进行模式匹配路由,例如:若为abc*则推入到所有abc*相对应的queue;若为abc.#则推入到abc.xx.one ,abc.yy.two对应的queue。

    (2)RoutingKey:是RabbitMQ实现路由分发到各个队列的规则,并结合Binging提供于Exchange使用将消息推送入队列;

    (3)Queue:是消息队列,可以根据需要定义多个队列,设置队列的属性,比如:消息移除、消息缓存、回调机制等设置,实现与Consumer通信;

  3、消息消费者(Consumer):主要负责消费Queue的消息,同样基于TCP协议,通过建立Connection和Channel与Queue传输消息,一个消息可以给多个Consumer消费;

  4、关键名词说明:

  Publisher

是Message的生产者,Publisher这个Clients产生了一些Message。

  Consumer

Message的消费者,Publisher产生的Message,最终要到达Consumer这个Clients,进行消费。

  Exchange

指定消息按什么规则,路由到哪个Queue,Message消息先要到达Exchange,在Server中承担着从Produce接收Message的责任。

  Queue

到达Exchange的消息,根据制定的规则(Routing key)到达对应的Queue,在Server中承担着装载Message,是Message的容器,等待被消费出去。

  Routing key

在Exchange和Queue之间隐藏有一条黑线,可以将这条黑线看成是Routing key,Exchange就是根据这些定义好的Routing key将Message送到对应的Queue中去,是Exchange和Queue之间的桥梁。

  Broker

之前一直不理解这个Broker,其实Broker就是接收和分发消息的应用,也就是说RabbitMQ Server就是Message Broker。

  VirtualHost

虚拟主机,一个Broker里可以开有多个VirtualHost,它的作用是用作不同用户的权限分离。

  Connection

是Publisher/Consumer和Broker之间的TCP连接。断开连接的操作只会在Publisher/Consumer端进行,Broker不会断开连接,除非出现网络故障或者Broker服务出现问题,Broker服务宕了。

  Connection: Channel:

如果每一次访问RabbitMQ就建立一个Connection,那在消息量大的时候建立TCP Connection的开销就会很大,导致的后果就是效率低下。

转载于:https://www.cnblogs.com/88phper/p/8329275.html

RabbitMQ 关键词解释相关推荐

  1. java同步关键词解释、synchronized、线程锁(Lock)

    1.java同步关键词解释 21.1 synchronized synchronized是用来实现线程同步的!!! 加同步格式: synchronized( 需要一个任意的对象(锁) ){ 代码块中放 ...

  2. 小白入门炒股票关键词解释及细节注意事项

    炒股关键词解释 文章目录 炒股关键词解释 名称解释 五档 委买手数 委卖手数 委比与委差 委比 委差 量比 成交额 换手(率) 外盘 内盘 市盈(率) PE 市净(率) 每股收益 净资本 ROE 总股 ...

  3. java gc --- 关键词解释

    分代gc java的堆内存主要分为young generation与old generation,这两块分开回收.这就是所谓的分代gc 其中young generation又分为一个eden spac ...

  4. java 后台开发关键词解释

    bean类:是一些实体类,包括viewbean,databean等等. action类:可作为接收显示层的数据,连接显示层和业务逻辑实现层的控制层. model类:MVC中model层就是到层.在ja ...

  5. 深度神经网络关键词解释

    神经网络的学习的目的是找到使损失函数的值尽可能小的参数.这是寻找最优参数的问题, 解决这个问题的过程称为最优化 (optimization)而由于参数空间复杂,无法轻易找到最优解 1随机梯度下降法 ( ...

  6. rabbitmq可靠性投递_解决RabbitMQ消息丢失问题和保证消息可靠性(一)

    工作中经常用到消息中间件来解决系统间的解耦问题或者高并发消峰问题,但是消息的可靠性如何保证一直是个很大的问题,什么情况下消息就不见了?如何防止消息丢失?下面通过这篇文章,我们就聊聊RabbitMQ 消 ...

  7. Spring Boot(十三)RabbitMQ安装与集成

    一.前言 RabbitMQ是一个开源的消息代理软件(面向消息的中间件),它的核心作用就是创建消息队列,异步接收和发送消息,MQ的全程是:Message Queue中文的意思是消息队列. 1.1 使用场 ...

  8. 《RabbitMQ 实战指南》第四章 RabbitMQ进阶(上)

    <RabbitMQ 实战指南>第四章 RabbitMQ进阶(上) 文章目录 <RabbitMQ 实战指南>第四章 RabbitMQ进阶(上) 一.简介 二.消息何去何从 1.m ...

  9. 基于springboot整合的rabbitmq

    技术:springboot1.5.2 + maven3.0.5 + rabbitmq3.7.13 + jdk1.8 概述 RabbitMQ是对高级消息队列协议(Advanced Message Que ...

最新文章

  1. python使用imbalanced-learn的InstanceHardnessThreshold方法进行下采样处理数据不平衡问题
  2. 中文任务全面超越BERT:百度正式发布NLP预训练模型ERNIE(附项目地址)
  3. (*长期更新)软考网络工程师学习笔记——数据链路层与网络层的相关计算题
  4. UNIX网络编程笔记(3):简单的并发服务器
  5. loadrunner11完整卸载
  6. 迷宫(AHOI2016初中组T3)
  7. 干货|219个opencv常用函数汇总
  8. postgres 密码更改
  9. 用fileupload处理文件上传
  10. linux去掉空行的几种方法
  11. 微信小程序云开发教程-云函数操作数据库-增、查
  12. 使用cmd和excel完成批量复制所需文件夹和文件
  13. 磁盘阵列服务器安装操作系统,板载RAID功能制作磁盘阵列并安装操作系统
  14. 支付接口的开放有什么好处?第三方支付API文档如何对接?
  15. 不知道读什么?5种方法教你打造私房书单!
  16. Activiti7工作流引擎:进阶篇(十) 多实例
  17. 还在死守TCP吗,来看看即将成为HTTP3.0标准协议的QUIC
  18. 做一个植物大战僵尸有多难?python教你几步搞定
  19. 游戏里WASD移动控制人物的操作,用js写出的效果,简单易上手!
  20. PHP+MySQL实现上传图片的显示

热门文章

  1. WebApp的前端所遇问题
  2. BusinessEtiquette,Communication Skill(外企职场商务礼仪与沟通技巧)
  3. 计算机一级表格样式在哪儿,word表格样式在哪 word表格样式在哪里
  4. mysql5.6 二进制免编译安装
  5. C++ 程序运行前内存分区模型
  6. 数据转移-从MySQL到Hive
  7. 互联网晚报 | 1月25日 星期二 | 知乎首次举办上星晚会;微信视频号上线首个付费直播间;淘宝天猫“春节不打烊”活动正式上线...
  8. 2021快手男性消费用户洞察
  9. 互联网晚报 | 8月27日 星期五 | 爱奇艺取消未来几年偶像选秀节目;百度App月活跃用户突破6亿;陌陌连续26个季度盈利...
  10. 如果HR这么跟你说,我建议你再考虑一下,否则很容易踩坑